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SECTION 1 
INTRODUCTION 


This manual describes the assembly language and assembler processing used to write, 
assemble, and execute programs for the SPERRY UNIVAC 'V70 series computers. . 


1.1 V70 SERIES ASSEMBLY LANGUAGE 


The assembly language is a symbolic representation of the programmable capabilities of the 
V70 series computers. Using assembly language, the programmer is able to specify the 
machine instruction codes symbolically and to address memory locations by alphanumeric 
symbols of his own choosing, providing a flexibility not attainable with absolute addressing. 


Internally, the computer obeys instructions kept in its memory in 16-bit binary format. For 
example, the instruction: 


0001000000001 111 


when executed causes the A register to be loaded with the contents of location 15 (decimal). 
In octal the same instruction is written: 


010017 

However, it is not necessary to learn the octal or binary representation of the computer’s 
instruction repertoire. Instead, a user can write his program using a symbolic language and 
then use another computer program, the DAS (Data Assembly System) assembler, to convert 
the instructions to binary upon input. The instruction given previously is then written: 

LDA 017 
or, if decimal working is preferred: 

LDA 15 


which is read as "'Load the A register with the contents of location 15 (decimal).’”’ 


The DAS assembler translates the statement "LDA 15” into its binary machine language 
equivalent, i.e.: 


LDA 15 ———» DAS ASSEMBLER 0001000000001 1 71 


Similarly: 
STX 0177 


is translated by the DAS program to form the instruction '’Store the X register contents in 
location 0177." 


The DAS assembler has many other capabilities than translating source instructions one-for- 
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-one into their binary equivalents. A primary feature is allowing the programmer to represent 
memory locations with symbolic labels instead of requiring absolute addresses. Another 
feature allows the programmer to define data constants and character constants without 
prior conversion to binary or octal values. For example, suppose the user wishes to load the A 
register with the value 64 at some point in his program. He could do this with the following 
statements: 


VALU DATA 64 


LDA VALU 


The first statement defines a word of data having the value 64; "VALU”’ is a symbolic label 
that can be used to address that data word. The second statement is an instruction to load 
the A register with the contents of memory location ’’VALU”. The programmer need not be 
concerned with the absolute location of the data word. 


An even simpler version--requiring only one statement--can be written using a "'literal’’ 
constant: 


LDA =64 


In this version, the assembler itself will designate a location in which the value 64 is tq be 
placed. 


DAS assembly language allows the user to give directions to the assembler, called assembler 
directives, to perform such functions as defining program loading addresses, data locations 
(such as the DATA directive above), subroutine linkage, and input/output functions; further 
control features include conditional assembly directives and a macro capability. Comments 
can be added between symbolic source statements or appended to the statements themselves 
to enable easier checkout and program documentation. 


By using the DAS assembly language, the programmer is able to write functional application 
programs and control the operation of the assembler. Symbolic coding reduces machine 
language bookkeeping and fully utilizes the computer capabilities without a corresponding 
increase in the time required for programming. 


1.2 DAS ASSEMBLERS 


The principal objective of any assembler is to translate source programs written in a 
symbolic machine language into the more precise numeric language of the computer. The 
assembler (DAS) achieves this objective by converting programmer-prepared symbolically 
coded instructions, directives, and data (the source program) into their binary machine 
language equivalents (the object program). 


DAS processes source programs in two passes. The first pass defines user-designated 
symbols. The second pass produces an assembly listing and the object program. 


x 


Two versions of DAS are available: DAS 8A and DAS MR, described in the following 
subsections. 
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1.2.1 DAS 8A Assembler 


DAS 8A is a stand-alone program that can operate on a minimum system (8K of memory). It 
produces absolute object code that can be loaded by the stand-alone binary load/dump 
program (BLD II). 


Because DAS 8A was designed to operate in a restricted environment, it does not provide 
some of the features described in this book, principally the macro directives (section 4.11). 
Appropriate error messages are generated if a source program contains statements not rec- 
ognized by the DAS 8A assembler. 


1.2.2 DAS MR Assembler 


DAS MR is a macro assembler which produces relocatable object code that can be loaded 
into any area of memory. itis available either as a free-standing program or as an integral part 
of the MOS or VORTEX I/VORTEX II operating system. DAS MR includes all of the features 
described in this book. 


1.3 BIBLIOGRAPHY 


The following manuals contain information on Sperry Univac hardware and software that 
would be helpful to the 70 series computer user (the x at the end of each document number is 
the revision number and can be any digit 0 through 9): 


Title Manual Number 
V70 Architecture Reference Manual 98 A 9906 00x 
VORTEX | Reference Manual 98 A 9952 10x 
VORTEX II Reference Manual 98 A 9952 24x 
MOS Manual 98 A 9952 09x 
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SECTION 2 
STATEMENTS 


Input to the assembler is supplied by the user in the form of source statements. A statement 
constitutes one input record and may be in either a position-dependent fixed format or free 


format. 


Each statement can be classified, according to its operation field entry, into one of the 
following three groups: 


a. Computer instruction statement 
b. Assembler directive statement 


c. Macrocall statement 


Computer instructions are instructions which are translated into machine-executable code on 
a one-to-one basis. 


Assembler directives are requests to the assembler to perform certain operations during the 
assembly. These directives may define symbols, reserve and/or initialize data areas, control 
the listing, and alter the normal processing of statements. The FORM directive allows the user 
to symbolically define a bit-placement pattern whose name may subsequently appear in the 
operation field. 


A macro call statement represents a predefined block of statements (usually a block of 
instructions). The macro allows the entire block to be included, with varying parameters, each 
time the macro name appears in the operation field of a source statement. 


This section describes the syntax of composing source statements. A summary of instructions 
is given in section 3. Assembler directives and macros are described in section 4. 


2.1 CHARACTER SET 


Source statements are written with the following DAS character set: 


Alphabetical characters ABCDEFGHIJKLMNOPQRSTUVWXYZ 
Numerical Characters 0123456789 
Teletype characters CR (carriage return) 
LF (line feed) 
Special characters + (pius sign) 
- (minus sign) 
(asterisk) 
/ (slash) 
(period) 
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(blank) 
@ (at sign) 
[ (left bracket) 
] (right bracket) 
< (less than) 
> (greater than) 
' (up arrow) 
- (left arrow) 
= (equal sign) 
: (comma) 
: (prime) 
( (left parenthesis) 
) (right parenthesis) 
/ (backslash) 
! (exclamation point) 
5 (quotation mark) 


# (pound sign) 

% (percent sign) 
& (ampersand) 

: (colon) 

: (semicolon) 

? (question mark) 
$ (dollar sign) 


In addition, any of the 128 ASCII characters (see appendix B) may be used anywhere that 
characters appear between paired apostrophes or brackets, in comments, literals, and in 
instruction operands. 


2.2 STATEMENT FORMAT 


A DAS source program consists of a sequence of source statements. Each source statement is 
input as one record. A punched card is one record, as is one line punched to paper tape and 
terminated by a carriage return and line feed. 


A source statement may contain a maximum of 80 characters. If a source record contains 
more than 80 characters, then the record is truncated to 80 characters. If a record contains 
less than 80 characters, the assembler supplies blank characters to fill out 80 character 
positions. If an assembler source record is completely blank, the source record is ignored by 
the assembler. 


Each source statement comprises a combination of label, operation, variable, and comment 
fields, depending on the requirements of the computer instruction or assembler directive. One 
computer instruction is generated by each instruction source statement. None, one, or more 
words of object code may be generated by each assembler directive, depending on the 
operation and variable field entries. A standard format for DAS source statements, where 
each field is separated by one or more blanks and begins in a standard line position, is shown 
in figure 2-1. Alternative formats may be used, prime among them being the use of commas 
as field separators. A detailed treatment of statement item placement for various input media 
is given in section 5. 
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OPERATION VARIABLE 
1 | 678 15 16 29 
COMMENT IDENTIFICATION 


30 72 73 8C 
[rnraranize WORD count | | 001] 


Figure 2-1. Format for Source Statement Records 


The fields are described further in the following subsections. 


2.2.1 Label Field 


The Label Field is the leftmost field on each source statement. It is either blank (no label), or 
it is used to contain a symbol (section 2.4) created by the programmer. If a label is present, it 
must begin in character position 1. 


For DAS 8A, symbols in the label field comprise one to four alphanumeric characters; for 
DAS MR there may be from one to six such characters. The first character of asymbol is an 
alphabetic character, pound sign (#), or dollar sign (the dollar sign and pound sign are used 
in the Sperry Univac software and should not be used in normal user programs). 


Examples 


16 30 


valid jabel (DAS MR) 

valid label (DAS 8A) 

valid label 

valid label 

valid label 

valid label 

invalid--must begin in position 1 
invalid--cannot begin with a number 
invalid characters 


An entry in the label field is always optional for instruction statements. It is optional for most 
assembler directives; however, certain assembler directives (EQU, SET, etc.) require a label 
field entry. 


The programmer generally labels a statement to identify the statement. Symbols in the label 
field identify program points for reference by other parts of the program. They make a 
program point or particular numeric value more easily identifiable. The first appearance of a 
symbol in the label field establishes its identity (most commonly a relative or absolute 
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address) throughout the remainder of the program. A previously established symbol is 
referenced by placing it in the variable field of the source statement. When the symbol is 
used, the DAS assembler substitutes the previously assigned value from its symbol table. 


Example 

START JMPM FETCH Call Fetch routine. 
DAR Decrement counter in A. 
JANZ START Loop back if A not Zero. 


In this example, the label field is used in the first statement to establish a user symbol for the 
location of the first statement in a loop. This label, START, is later referenced in the third 


statement as the return point for another loop iteration. 


Label field entries are also used to establish the name of a user-written macro definition 
(section 4.11). 


2.2.2 Operation Field 


The Operation Field is to the immediate right of the label field. The entry in this field 
describes to the assembler the specific type of statement that has been entered, thus 
determining how it should be processed. Entries in this field are composed of from one to six 
alphanumeric characters that may describe a machine instruction, assembler directive, or a 
macro call. An asterisk may follow certain instruction mnemonics to specify indirect 
addressing (see section 3). It is possible to redefine mnemonics with OPSY assembler 


directives (section 4.2.1). 


An entry in the operation field is always required, and if not supplied by the programmer, will 
cause an ’'undefined operation” error code to be generated. 


Examples 


30 


2.2.3 Variable Field 


The Variable Field is to the immediate right of the operation field. The purpose of this field 
varies according to the requirements of the operation defined by the source statement. The 
variable field can contain none, one or more symbols, constants or expressions combining 
symbols and constants. Multiple entries are separated by commas. 


The types of entries that may appear in the variable field are described in section 2.3 
(constants), section 2.4 (symbols), and section 2.5 (expressions). 
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Examples 

1 8 30 __ 
LDA Load A register with contents of TAB. 
ADDI Add 16 to the A register. 
JMP Jump to program location PILL. 
STXE* Store X register indirect, indexed by B. 
LSRA Logical shift right A register 7 bits. 
TAR increment A register (has no variable). 


2.2.4 Comment Field 


An optional comment field follows the variable field in all source statements. This field is used 
for programming notes. An entire line of comment may be entered if an asterisk is coded in 
the first position. The assembler ignores all comments in the object code production process, 
but lists comments and comment lines with the program listing output. 


On punched cards, the comment field generally extends from position 30 to position 72. 
Positions 73 through 80 can be used to sequence cards, simplifying collation ifa card deck is 
accidentally dropped. 


Examples 


Note: The assembler scans for data in columns 1-72 and if the record is not a comment, there must 
be a valid operand defined prior to column 72. 


2.3 CONSTANTS 
A constant is a number, or character string, whose value is specified directly by the 


programmer in the variable field of a source statement. DAS recognizes decimal integers, 
octal integers, floating point numbers, and character constants. 


In the following descriptions of DAS constants, unsigned numbers are considered positive. 
2.3.1 Decimal Integers 


A decimal integer is a signed (+, -) or unsigned string of from one to five decimal digits (0 
through 9). The first digit must not be a zero, since a leading zero signifies an octal number. 
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Decimal integers are converted to a right-justified 15-bit value, in the range - 32,768 through 
+ 32,767, with the high order bit representing the sign (O = positive, 1 = negative). Negative 
numbers are stored in twos complement representation. 


Examples 
1 Decimal integer +1 
20 Decimal integer +20 
-3 Decimal integer - 3 
- 9000 Decimal integer - 9000 
6,099 Invalid--no commas may appear 
144000 invalid--out of range 


2.3.2 Octal Integers 


An octal integer is a string of from one to six octal digits (O through 7), preceded by a leading 
zero. The conversion from octal to binary is straightforward. The number is right-justified in 
the 16-bit word and may have a range of 0 through 0177777. Octal numbers may optionally 
be signed (although they normally are not) and will be represented in twos complement form. 


Examples 
07 Octal constant 7 
023 Octal constant 23 
0123 Octal constant 123 
0677 Octal constant 677 
0177777 Octal constant 177777 
5612 Invalid octal--no leading zero 
07581 Invalid digit 


2.3.3 Floating Point Numbers 


Floating point numbers may be specified in the following formats: 
) tinteger.fraction + exponent 
)+ integer.fractionE + exponent 
) £integer.fractionD + exponent 


where: 
) the right parenthesis indicates a floating 
point number. 
+ is a minus sign (negative number) or an 
optional plus sign (positive number). 
integer is the integer portion of the number (if 


any). 


is the decimal point and must appear. 
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fraction is the fractional portion of the number 
(if any). 
E+ exponent is the signed (optional if positive) 


exponent (if any). The letter "E’’ may 
be omitted in the exponent if desired. 


D+exponent generates a double precision constant. 
A real constant is generated in all 
other cases. 
At least one digit must appear in the number. 


The number is stored in one of the following formats: 


Single Precision (Real) 
14 13 12 #11 #10 9 8 7 6 5 4 3 2 1 0 


Exponent | Fraction (high) 


Fraction (low) 


15 
a 


Double irae 
13. «12 10 9 


Cie ee 6 6 sal tee 
is | Fraction (high) 
jo 
0 | 


Fraction (mid) 


Fraction (low) 


The exponent is represented in an excess 128 format so that the smallest exponent 
representable contains all zeros. An exponent field containing 128 (0200) corresponds to an 
exponent value of 0. The largest exponent representable contains all ones. 


The fraction is expressed in a modified sign-magnitude format. Rather than inverting the sign 
bit for negative numbers, the complete word in which the sign appears is inverted. In single 
precision, this inverts the exponent, the sign, and the high 7 bits of the fraction. In double 
precision, the sign and the high 15 bits of the fraction are inverted. 


The number is zero represented by all zeros. All other numbers are normalized. 


Examples 
35:5 The real number 5.5 (five and a half) 
)60.00079 The real number 60.00079 
)6. + 10 The real number 60000000000. 
)09.D-2 The double precision number .O9 
)09.E-2 The real number .O9 
).1E-12 The real number .0000000000001 
)-4. + 20 The real number - 400000000000000000000. 
16.62 Invalid--no right parenthesis. 
)16E2 Invalid--no decimal point. 
JE2 Invalid--no digit. 
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2.3.4 Character Constants 


A character constant consists of one, two, or more ASCII characters enclosed by primes (’). 
Any of the 128 ASCII characters may appear in a character term. To code a prime character 
in DAS MR, use two primes in succession; this cannot be done in DAS 8A, however. Note that 


blanks are also recognized as characters. 


When a single alpha constant is defined by the DATA directive (section 4.4.1), DAS MR left- 
justifies it in the field and fills the remaining positions with blanks. In other DAS MR and all 
DAS 8A statements, a single alpha constant is right justified with leading zeros. 


Examples 

‘STRING' Valid character constant. 

"THIS ' Valid character constant. 

“1s” Valid character constant. 

'A' l-character constant: = 'A ’ in DAS MR, 
= 'OA' in DAS 8A. 

‘I CAN''T' (DAS MR only)--coded as | CAN’T. 

MMM Invalid--surrounding primes missing. 


2.3.5 Address Constants 


An address constant is a syinbol, number, or expression which may be enclosed in parentheses. It 
generates a 15-bit direct address (bit 15 = QO). 


Examples: 


A Address constant 
(31) 


where A is an address syrnbol whose value is taken from the symbol table by DAS. 


2.3.6 Indirect Address Constant 


An indirect address constant is an address constant enclosed in parentheses followed by an 
asterisk. It generates a 15-bit indirect address (bit 15 = 1). 


Examples: 


(At2)"— (3)" (A)* 


2.3.7 Binary and Hexadecimal Constants (DAS MR with VORTEX I and 


VORTEX II) 
Binary and hexadecimal constants occupy one word of main memory and are right justified. 
Examples: 
B‘101101' Positive binary constant 
-B‘101101' Negative binary constant 
X‘ABSF’ Positive hexadecimal constant 
X'ABOF’ Negative hexadecirnal constant 
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2.3.8 Literals 


A literal term or simply, literal, is a constant or expression preceded by an equal sign (=). A 
literal represents data, rather than an address of data. The appearance of a literal directs the 
assembler to assemble the data specified in the literal, store this data in an assembler. 
maintained literal pool, and assemble the address of the data into the current instruction. 
The literal pool is assigned addresses starting with the value of the literal’s location counter 
when the END directive is processed. Duplicate values are discarded in the literal pool. In 
general, literals can be used whenever an address is permitted in the variable field. 


NOTE. 


The literal pool may not be assembled into COMMON areas. Any attempt to place 
literals into COMMON areas is flagged as an error and the mode of the location 
counter is changed to program relocatable. 


Literals may contain undefined symbols, although use of undefined symbols in literals may 
cause extraneous words to be allocated within the literal pool. 


The use of literal terms allows the programmer to both define and reference a constant word 
in the same machine instruction statement. 


Examples 


LDA =5 Load A register with the constant 
5. The value 5 is placed in 
the literal pool, and its address 
(in the pool) coded in the LDA 
instruction. 


ADD =255 Add the value 255 to the A register. 
The value 255 is placed in the 
literal pool, and its address 
coded in the ADD instruction. 


ORA =07077 Inclusive OR with the A register. 
: The indicated value is placed 
in the literal pool. For the 
: ERA (Exclusive OR instruction) 
ERA =07077 the same literal pool location 
is addressed, thus minimizing 
storage required for the mask 
word. 


2.4 EXPRESSIONS 


An expression is a single constant, a single symbol, or any combination of constants and 
symbols connected by operators. Operators are described in section 2.4.1. 


A discussion of multi-term expression evaluation is given in section 2.4.2 (expression 


evaluation), section 2.4.3 (address expressions), and section 2.4.4 (mode determination). 
Section 2.4.5 describes literals. 
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2.4.1 Right and Left Shift Expressions (DAS MR with VORTEX | and 
VORTEX Il) 


The Right and Left Shift Expressions are used to right or left shift the bits in a word by the number of 
bits specified in the command (X). 


The expression for a Left Shift is .—X where X is an integer from 1to 15. The. Xis placed to the 
immediate right of the word which has its bits shifted first tn the expression evaluation. 


The expression for a Right Shift is «—(-X) where X is an integer from 1 to 15. The «—(-X) is placed to 
the immediate right of the word which has its bits shifted first in the expression evaluation. 


The bit shifted out of the Oor 15 bit position is not rotated into the 15 or Obit position. The vacated bit 
positions are filled with zeroes. 


Example: 


ALPHA EQU B’‘1001' 
LDA! ALPHA «9 


The events which occur are: 
@ The bits in position O through 8 of ALPHA are left shifted nine bits. 
@ Bits 7 through 15 are lost. 
@ Bits O through 8 are zero. 
m The A Register is loaded with the results of the left shift of the ALPHA field. 


a After the shift, the A Register contains 0001001000000000. 


2.4.2 Operators 
The following operators are allowed in expressions: 


Operator Meaning 
+ Addition 


= Subtraction 
Multiplication 
/ Division 
Arithmetic operations always involve all 16 bits of the computer words, and are performed 
from left to right, with multiplication and division occurring before addition and subtraction. 


Thus, A + B/C * D in DAS ts equivalent to A + (B/C) * D in conventional notation. 


The rules for coding expressions are: 
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a. An expression cannot contain two terms or two operators in succession. 


b. An expression with a leading minus sign (-) is evaluated as though a zero preceded the 
minus sign. 


c. Anexpression with a leading plus sign (+ ) is evaluated as though a zero preceded the plus 
sign. 


d. A multi-term expression cannot contain an external symbol. If it does, an "invalid 
relocation’’ error message is printed. 


e. Character constants used in mulit-term expressions may contain only one or two 


characters. 
Examples 
A+1 Valid expression 
‘'A'+1 Valid expression 
"A'-'B' Valid expression 
6443/2 Valid expression (evaluates to 3221) 
-1*2 Valid expression (evaluates to - 2) 
10/5*2 Valid expression (evaluates to 4) 
6+6+6-OMS Valid expression (evaluates to 18 minus 
the value of OMS) 
"A'+4+'B' Invalid--adjacent operators 
"ASM'+2 Invalid--contains a long character string. 
2.4.3 Expression Evaluation “as 


A single-term expression takes on the value of the term involved. 
A multi-term expression is reduced to a single value, as follows: 
a. Each term is evaluated. 
b. Arithmetic operations are performed from left to right. 
c. Division always yields an integer result; any fractional portion of the result is dropped. 
d. Division by zero is permitted and yields a zero result. 


Negative values are carried in twos complement form. The value of the expression must be in 
the range ~ 32,768 to 32,767 or the results may be meaningless. 


2.4.4 Address Expressions os 


In addition to its evaluated numerical value, the relocatability of an expression is determined. 
The relocatability of an expression depends upon the term(s) in the expression. The 
expression is absolute if it contains a single absolute value. The expression is relocatable if it 
contains a single relocatable value. A multi-term expression may be absolute or relocatable. 
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Absolute and relocatable expressions are derived from the term or combination of terms 
composing them, and the way in which these terms are combined. Table 2-1 shows, for each 
arithmetic operation, whether the result is absolute (abso), relocatable (relo), or illegal. 


Table 2-1. Arithmetic Operation Results (DAS MR only) 


= abso A 


A = = abso A = relo A = relo 

B = abso B = relo B = abso B = relo 
A+B abso relo relo illegal 
A-B abso illegal relo abso 
A*B abso illegal illegal illegal 


A/B abso illegal illegal illegal 


2.4.4.1 Absolute Expressions 


An absolute expression is a constant, an absolute symbol, or any arithmetic combination of 
absolute terms. An expression may be absolute even though it contains relocatable terms, 
alone or in combination with absolute terms, under the following conditions: 


a. There must be an even number of relocatable terms in the expression and the terms must 
be paired. Otherwise, an "invalid relocation”’ error message will result. 


b. Each pair of terms must have opposite signs and the same relocatability. (Program, blank 
COMMON or the same named COMMON). The paired terms do not have to be 
contiguous. 


c. Relocatable terms entering into multiply or divide operations are considered absolute 
terms, with the same value. 


The pairing of relocatable terms with the same relocatability and opposite signs cancels the 
effect of the relocation, since both symbols would be relocated by the same amount. Thus, the 
value represented by the paired terms remains constant, regardless of program relocation. 


An absolute expression reduces to a single absolute value. 


Examples 


lf A and B are relocatable symbols and X and Y are absolute symbols or terms, the following 
are absolute expressions: 


x abs = abs 

A-B relrel = abs 

A-B+X rel-rel+abs = abs 

X+Y abs+abs = abs 

X*Y abs*abs = abs 

X/Y abs/abs = abs 

A*B rel*rel is interpreted as abs*abs = abs 


(see discussion below under Relocatable 
Expressions). 
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— 2.4.4.2 Relocatable Expressions (DAS MR Only) 


A relocatable expression is a relocatable term or a combination of relocatable and absolute 
terms under the following conditions: 


a. There must be an odd number of relocatable terms with the same relocatability. 


b. All the relocatable terms but one must be paired (see the description of pairing under 
ABSOLUTE EXPRESSIONS). 


c. Theunpaired term must not be directly preceded by a minus sign (- ). 
lf the above conditions are not met, an "invalid relocation” error message will result. 
Relocatable terms entering multiply or divide operations are considered absolute terms with 


the same value. A relocatable expression reduces to a single relocatable value. This value is 
the value of the expression, with the relocatability attributes of the unpaired relocatable term. 


Examples 


lf A and B are relocatable symbols and X and Y are absolute symbols, the following are 
relocatable expressions: 


A rel = rel 

A+X rel+abs = rel 

X+B abs+rel = rel 

A-B+A rel-rel+rel = rel 

A+2 rel+abs = rel 

X+B+Y abs+rel+abs = rel 

A*¥B+A rel*rel+rel is interpreted as 
abs*abs+rel = rel 


2.4.5 Logic Expressions (DAS MR with VORTEX | and VORTEX< Il) 


There is a set of logic expressions that can be interfaced with the arithmetic expressions. The logic 
expressions operate on 16-bit values in the sarne rnanner as the arithmetic operators. 


The logic expressions and their corresponding symbols are: 


AND & 
Inclusive OR ! 
Exclusive OR Ol ete 
NOT re 


2.4.6 Mode Determination 


The mode of an expression is determined by the mode of the symbols in the expression. The 
mode is determined by the following rules: 


a. Ifthe expression contains any mode E or C symbol, the expression is mode E. 


b. If the expression contains only mode A symbols, the expression is mode A. 


STATEMENTS 
c. If the expression contains mode A and R symbols, the mode of the expression is R if there is 
an odd number of mode R symbols. Otherwise, the mode of the expression is A. 


The following restrictions apply only to DAS MR and to FORTRAN-compatible output assembly 
with DAS 8A.: 


a. No expression can contain symbols of both modes E and C. 
b. Amode E expression comprises a single mode E symbol. 
c. NomodeE,C, or R expression can multiply or divide a mode E or C symbol. 


d. No expression can add or substract a mode C and a mode R symbol, or a mode E and a 
mode R symbol. 


e. Noexpression can add two or more mode E, C, or R symbols. 
f. AmodeAsymbol can be added to or subtracted from a mode C or R symbol. 
Examples 


The following program code illustrates expression mode determination rules. 


EEEE EXT Defines mode E. 

cccc COMN 6 Defines mode C 

RTN ENTR Defines a symbol (RTN) as mode R. 

TBL BSS 50 TBL is mode R 

ABL BSS "A'+5 ABL is mode R. 

LENG EQU *—TBL LENG is mode A (defines area iength). 
CALL EESE,TBL,LENG 
LDA *4+5 Legal, one-word relative forward. 
LDA CCCC+6 Illegal, one-word not R or A. 
LDXI CCCC+6 Legal, two-word instruction. 
LDA 0,1 Legal, loads CCCC +6 in A register. 
DATA EEGE+4 lilegal, value not zero. 
DATA cCCCC+t4 Legal. 
DATA CCCC+LENG Legal. 
DATA TBL+LENG Legal, mode is R. 

2.5 SYMBOLS 


A symbol is a character or combination of characters used by the programmer to symbolically 
define instruction addresses, data addresses, general purpose registers, and arbitrary values. 
Through their use in label fields and in operand fields they provide the programmer with an 
efficient method to name and reference program elements. The assembler creates a symbol 
table and assigns to each of the symbols written in the source program a value and a 
relocation bias (DAS MR ory); it also provides indicator flags when required by the program. 
This relieves the programmer of having to know the absolute address locations of code and 


data areas. 
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Symbols are formed from the following three classes of characters: 

a. Alphabetic characters: A through Z 

b. Numeric characters: O through 9 

Cc. Special character: pound sign (#) 
A symbol is formed from one to six characters (DAS MR) or one to four characters (DAS 8A) 
in length, chosen from the preceding classes. The first character must not be numeric. 


Symbols cannot contain imbedded blanks. 


Symbols may be classified as user symbols (section 2.5.1) and assembler-defined symbols 
(section 2.5.2). 


2.5.1 User Symbols 


User symbols are defined and used by the programmer to symbolically reference instruction 
and data area addresses, the general purpose registers, and arbitrary values. 


Although it is possible for the user to define user symbols that begin with the pound sign, this 
should not be done because conflicts can arise with V7O series system software, which uses 
the pound sign. 


Examples 
A User symbol. 
MAIN User symbol. 
BETA11 User symbol (DAS MR). 
BUFFER User symbol (DAS Mk). 
READ 1 User symbol (DAS MR). 
CON90 User symbol (DAS MR). 
128B Invalid--first character is numeric. 
CODE 1 Invalid--more than 4 characters (DAS 8A). 
RECORD 1 Invalid--more than 6 characters (DAS MR). 
RCD+A Invalid character in symbol. 
IN AREA Invalid--contains an imbedded blank character. 


2.5.2 Assembler-Defined Symbols 


Assembler-defined symbols are of a specialized nature and are used primarily to control the 
assembly process. They are unique in that they are not defined by the programmer, but by 
the assembler itself. All symbols that are not assembler-defined symbols must be properly 
defined by the user in his source program. 


2.5.2.1 Operation Field Symbols 


All instruction mnemonics and assembler directives appearing in the operation field are 
predefined by the assembler and control the processing of the source statement. 
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| CAUTION 


DAS assemblers reccgnize the complete instruction sets of all SPERRY UNIVAC 70 
series Computers, even when the system on which they operate lacks the hardware for 
executing a particular instruction. The programmer, therefore, must have a thorough 
knowledge of the instructions applicable to his system before attempting to assemble a 
program. 


Any other operation symbols are user symbols; these are comprised of OPSY-defined 
instruction mnemonics (section 4.2.1), FORM-defined symbols (section 4.4.4), and macro call 
names (section 4.13). 


2.5.2.2 Location Counter Symbols 


Current Location Counter (*). The assembler maintains a location counter to assign storage 
addresses to program statements. It is the assembler’s equivalent of the computer’s program 
counter. As machine instructions and data areas are assembled, the location counter is 
incremented to reflect the length of the assembled code or data. Thus, it always contains the 
address of the next available word. 


The location counter also has an associated relocatability mode, either absolute, program 
relocatable, or named FORTRAN COMMON relocatable. Modification of the current value and 
mode of the location counter is accomplished with the ORG directive. The location counter is 
never negative and is always less than 2"°. 


The programmer can reference the current value of the location counter by using the asterisk 
(*) character as a term in an operand. The asterisk term represents the word address of the 
beginning of the current instruction or data area. Use of the asterisk term in a literal 
address constant results in the assembler using the word address of the instruction 
containing the literal. 


The relocatability mode cf the asterisk term--absolute, program relocatable, or named 
FORTRAN COMMON relocatable--is dependent on the current mode of the location counter. 


Examples 
JMP *+4 Jump to the location 4 words down. 
LDA * Load A with the word at the 


current location counter (i.e., 
the ''LDA"”' instruction itself). 


DAS 8A Location Counters. DAS 8A has five standard location counters that have predefined 
names, as described in Table 2-2. These location counter names may be used in location 
counter control directives (section 4.3) for controlling the location counter values used during 
the DAS 8A assembly process. These names have special significance only in the location 
counter control directives; if used in instruction statements or other directives, they are 
considered user symbols. 


These five location counters are not applicable in DAS MR programs. 


2-16 


Counter 


AOR 


LTOR 


SYOR 


(blank) 


STATEMENTS 


Table 2-2. Standard DAS 8A Location Counters 


Initial Value 


002000 


000200 


001000 


000000 


004000 


2.5.3 Symbol Values 


Description 


Controls assignment of memory 
within an interface area common 
to two or more programs. 


Control assignment of memory 
to indirect pointers. 


Controls assignment of memory 
to literals. 


Controls assignment of memory 
to all system parameters. 


Used initially and normally 
by the assembler for memory 
assignments until/unless over- 
ridden by the use of the ORG 
directive 


Associated with every symbol is a value. The value is in the range - 32,768 through + 32,767. 
This value is substituted in place of the symbol whenever the symbol appears in the variable 
field of other source statements. 


A symbol's value is defined when it appears in the label field of a statement. The value 
assigned is one of two types: 


® For all instruction mnemonics and most assembler directives, the symbol is assigned the 


value of the current location counter. 


# Incertain assembler directives, the symbol is assigned the value of the variable field entry; 
these directives are: EQU, SET, MAX, MIN, OPSY, ORG, LOC, and BEGI. In addition, 
special purpose symbols are used in the label field for FORM and MAC directives. (All of 
these directives are described in detail in section 4.) 


2.5.4 Address Symbols and Relocatability 


2.5.4.1 Relocatability (DAS MR Only) 


In addition to having names and values, all symbols are associated with a set of attributes. 
These attributes describe how the symbol is handled by the assembler. 
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The most important attribute is that of relocatability. A relocatable program (DAS MR only) is 
one that has been assembled with its instruction and directive locations assigned in such a 
manner that it can be loaded and executed anywhere in memory. When such a program is 
loaded, the beginning memory address is specified, and a value (known as the relocation 
bias) is added to the addresses of subsequent relocatable instructions. The relocatable 
loader is used to load a program in any area of memory and modify the addresses as it loads 
so that the resulting program executes correctly. 


Programs can contain absolute addresses, relocatable addresses, or both. Symbols which 
refer to addresses that will change during program loading are relocatable. Other symbols, 
such as register numbers or buffer lengths, do not change with program loading and are 
called absolute symbols. Programs are usually assembled with a zero relocation bias on the 
first instruction. 


The assembler's location counter contains the (relative) address of the instruction or directive 
currently being executed. The location counter is absolute when it contains the actual address 
of the instructions, and relocatable when it contains an address relative to the start of the 
program. 


Symbols can be absolute or relocatable. If a symbol is equated to the location counter, it is 
relocatable if the location counter is relocatable. Otherwise, the symbol is absolute. 
Expressions (section 2.5), since they contain symbols, can be absolute or relocatable. 
Constants are always absolute. 


At the beginning of each instruction or data word generated by the assembler, the 
relocatability can be set by the ORG directive. On encountering an ORG directive, the 


assembler makes the location counter absolute if the corresponding expression is absolute, or 
relocatable if the corresponding expression is relocatable. 


2.5.4.2 Absolute Symbols 
Absolute symbols are those whose values are independent of the execution address. These 


symbols are used to represent such things as register numbers, fixed memory locations, 
buffer lengths, or bit masks. 


These symbols can be defined in the following two ways: 
a. By appearing in a label field when the location counter is in the absolute mode. 


b. By being defined as equivalent to some absolute value in directives (EQU, ORG, etc.). 


Examples 
ORG 0500 (Specifies absolute address origin.) 
START LDA VSYSs The label START is assigned an 
absolute value of 0500. 
TEN EQU 10 The label TEN is assigned an 


absolute value of 10. 


STATEMENTS 


2.5.4.3 Relocatable Symbols (DAS MR Only) 
Values of relocatable symbols are dependent upon the execution address of the program. 
They can represent such things as instruction addresses, data addresses, and addresses of 
other programs. 
Relocatable symbols may be defined in the following ways: 

a. By appearing in a label field while the location counter is in the relocatable mode. 

b. By being defined as equivalent to some relocatable value in directives (EQU, ORG, etc.) 
There are four major types of relocatable symbols: 


a. Program relocatable symbols, whose values depend on the program location. 


b. Blank COMMON relocatable symbols, whose values depend on the location of FORTRAN 
blank COMMON. 


c. Named COMMON relocatable symbols, whose values depend on FORTRAN named 
COMMON. 


d. External symbols, whose values depend on the location of separately assembled programs. 


Examples 


*NO ORG DIRECTIVE IN DAS MR ASSEMBLES AS RELOCATABLE. 
START LDA MERF The label START is assigned 
a value of relocatable zero. 


HERE EQU * Where the program counter is 
relocatable, assigns the 
relocatable value to the label 

RE. 


2.5.5 Symbol Modes 
Each symbol has one of the following modes assigned by the assembler: 


a. External (E) 


b. Common (C) 
c. Relative (R) 
d. Absolute (A) 
The mode of a symbol is determined by the following rules: 
a. If the symbol is in an EXT directive, the mode is E. 


b. Ifthe symbol is defined by a COMN directive, the mode is C. 


STAT 


EMENTS | 


If the symbol is a symbol in a program, or tf * is the current location counter value, the 


If the symbol is a number (numerical constant), the mode is A. 


If the symbol is defined by an EQU, SET, or similar directive, the mode of the symbol is that 
of the variable field expression in the directive. 


C. 
mode is R. 
d. 
e. 
Examples 
EXT 
UNIV COMN 
START ENTR 
CONS DATA 
TIME EQU 
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EDAT 


44 


24 


Symbol EDAT has mode E. 

Symbol UNIV has mode C. 

Symbol START has mode R (location 
counter relocatable) or mode 

A (location counter absolute). 
Symbol CONS has mode R (location 
counter relocatable) or mode 

A (location counter absolute). 


Symbol TIME has mode A. 


SECTION 3 
INSTRUCTION SUMMARY 


For use with DAS, SPERRY UNIVAC 70 series instructions are divided into six categories: 
types 1 through 5 and multiple register. Tables 3-1 and 3-2 list the characteristics and 
mnemonics of the instruction types. 


A complete list of V7O series instructions, arranged alphabetically by mnemonic, is given in 
appendix A. The details of the 16-bit configuration of each individual instruction word are 
given in the applicable system handbook. Also refer to the handbook for a complete 
description of addressing modes. 


Computer instructions have the general format for source statements described in section 2. 
A label is always optional in instruction statements. In the following descriptions of the 
individual instruction groups, the field format: 


Operation Variable 
is used, with the optional label being understood to precede the operation field when used, 
and the optional comment field to follow the variable field when used. In cases where the 
variable field contains more than one item or expression, these are always separated by 
commas. Mandatory elements of the field are in bold type, and optional items, in italic type. 


Table 3-1. Assembler Instruction Type Characteristics 


Parameter Multiple 
Register _ 


Words generated (Varies 
with 

Memory addressed instruc- 
tion 

Indirect addressing . group) 


Indexing 


Variable field 
expressions 


Microcoding 


* Except for immediate instructions. 


ore a 
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Table 3-2. Summary of Assembler Instruction Types * 


Type 3 | Type 4 Type 5 | Multiple 
Register 
JS3N BT AOFA LLRL AD 
JS3NM_ | IME AOFB LLSR ADI 
JXNZ JOF AOFX LRLA ADR 
JXNZM | JIFM ASLA LRLB COM 
JXZ OME ASLB LSRA DADD 
JXZM SEN ASRA LSRB DAN 
LDAI XIF ASRB MERG DEC 
LDBI CIA NOP DER 
JANZM _LDX! CIAB OAB DLD 
MULI CIB OAR INC 
ORAI COMP OBR JDNZ 
STAI CPA ROF JDZ 
STBI CPB SEL JN 
STXI CPX SEL2 LBT 
JBNZM  SUBI DAR SOF LD 
XAN DBR SOFA LDI 
XANZ DECR SOFB SB 
XAP DXR SOFX SBR 
XAZ EXC TAB SBT 
XBNZ EXC2 TAX ST 
XBZ HLT TBA T 
XEC IAR TBX 
JOFNM ~~ XOF IBR TSA 
XOFN INA TXA 
XS1 INAB TXB 
XS1N INB TZA 
XS2 INCR TZB 
XS2N IXR TZX 
JSINM = XS3 LASL ZERO 
XS3N LASR 
XXNZ 
JS2NM —-XXZ 


—  * Instructions used only with the V77-800 computer are described in section 3.7. 


3.1 TYPE 1 INSTRUCTIONS 


An assembler type 1 instruction occupies one computer word and is memory-addressing. It 
may optionally specify indirect or preindexed addressing. 
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Assembler type 1 instructions are: 


Normal Load/Store LDA Load A register 
LDB Load B register 
LDX Load X register 
STA Store A register 
STB Store B register 
STX Store X register 
Arithmetic ADD Add memory to A register 
SUB Subtract memory from A register 
MUL Multiply 
DIV Divide 
INR Increment memory 
Logic ANA AND memory and A register 
ORA Inclusive OR memory and A register 
ERA Exclusive OR memory and A register 


The format of type 1 instructions varies according to the type of addressing, as follows: 


Operation Variable 


XXX address Direct addressing 
XXx* address Indirect addressing 
or 
XXX (address)* 
XXX incr,i Indexed addressing 
where: 
XXX is a type 1 instruction mnemonic 
address is an address expression 
incr is an fndexing increment, < 0512 


i specifies an index register: 1=X, 2=B 


lf the direct form of instruction is used, DAS selects the addressing mode of the generated 
computer instruction according to the following rules: 


a. Direct Addressing: If the specified address is 2047 or below, direct addressing is used. 

b. Relative Addressing: If the specified address is above 2047 but not more than 512 and not 
less thart one word beyond the current instruction, the mode of addressing is relative to 
the program counter. 

c. Indirect Addressing: If neither of the preceding conditions for direct or relative addressing 


is true, an address within the range 0 through 511 (called indirect pointer) is generated 
and the indirect pointer address will be used in the instruction in the indirect mode. 


3-3 


INSTRUCTION SUMMARY 


Indirect addressing is specified by an asterisk after the mnemonic or after-a variable field 
expressed in parentheses, e.g.: 


LDA* address 


LDA (address) * NOTE CAUTION BELOW. 


The instruction will be coded to address a location in lower core containing the address of the 
word to be accessed. Indirect addressing to five levels is permitted and is accomplished by 
setting the high-order bit at the indirect address location(s). 


CAUTION 


Only the first form should be used in DAS 8A (i.e., LDA*). In the second form (i.e., 
address)* DAS 8A will force bit 15 to a 1, changing the instruction. 


Indexing is specified by two expressions in the variable field. The first is the indexing 
increment and is less than 512. The second specifies the indexing register: X register = 1, 
and B register = 2. Preindexing is used. (Type 1 instructions cannot be postindexed.) 


Examples 


LDA 0500 Load A register with the contents 
of memory location 0500. Addressing 
is direct. 


LDA *4+12 Load A register with the contents 
of the word 12 locations down 
from the LDA instruction. 
Addressing iS program counter 
relative. 


LDA 070000 Load A register with the contents 
of memory location 070000. An 
indirect address is generated 
pointing to a location in lower 
core containing the address 
(070000). 


LDA* TIN Load A register with the contents 
: of the location whose address 
is contained at TIN, i.e., load 
. A register with the contents of 
TIN DATA 05100 location 05100. Addressing is 
indirect. 


LDA* IND1 This shows an example of multiple 
. indirect addressing to 3 levels. 
The A register is loaded with 
: . the contents of memory location 
IND1 DATA (IND2)* 050. 
IND2 DATA (IND3)* 
IND3 DATA 050 
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LDA 


0300, 1 


INSTRUCTION SUMMARY 


Load A register with the contents 
of the memory address specified 
by the sum of the X register 
contents and 0300. Thus, if 

the X register contains 0200, 

the operand for this instruction 
is in memory address 0500. 


3.2 TYPE 2 INSTRUCTIONS 


An assembler type 2 instruction occupies two consecutive computer words and is memory- 
addressing. The second word is the address of a jump, jump-and-mark, or execution 
instruction; or the operand specified by an immediate instruction. 


Assembler type 2 instructions are: 


Immediate 
Load/Store 
Arithmetic 
Logic 

Jump- 
Jump and-Mark 
JMP JMPM 
JOF JOFM 
JOFN JOFNM 
JAP JAPM 
JAN JANM 
JAZ JAZM 
JBZ JBZM 
JXZ JXZM 
JANZ JANZM 
JBNZ JBNZM 
IXNZ JXNZM 
JSS1 JSIM 
JSS2 JS2M 
JSS3 JS3M 
JSIN JSINM 
JS2N JSZ2NM 
JS3N JS3NM 


LDA! 
LDBI 
LDXI 
STAI 
STBI 
STXI 
ADDI 
SUBI 
MULI 
DIVI 
INRI 


“ANAI 


ORAI 
ERAI 


Execute 
XEC 
XOF 
XOFN 
XAP 
XAN 
XAZ 
XBZ 
XXZ 
XANZ 
XBNZ 
XXNZ 
X$1l 
X$2 
X$3 
XSIN 
XS2N 
XS3N 


Load A register immediate 
Load B register immediate 
Load X register immediate 
Store A register immediate 
Store B register immediate 
Store X register immediate 
Add to A register immediate 
Subtract from A register immediate 
Multiply immediate 

Divide immediate 

Increment immediate 

AND immediate 

Inclusive OR immediate 
Exclusive OR immediate 


Unconditionally 

lf overflow set 

If overflow not set 

If A register positive 

If A register negative 

lf A register zero 

lf B register zero 

If X register zero 

If A register not zero 

lf B register not zero 

If X register not zero 

lf SENSE switch 1 set 

lf SENSE switch 2 set 

lf SENSE switch 3 set 

lf SENSE switch 1 not set 
If SENSE switch 2 not set 
lf SENSE switch 3 not set 
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The immediate instructions have the following format: 


Operation Variable 


xxx value 
where: 
xxxi is an immediate instruction mnemonic 
value is any expression value 


The format of type 2 program control transfer instructions is the same as for type 1 direct or 
indirect addressing. Since a full word is allocated to the address, the assembler will never 
need to code an indirect address pointer for the purpose of reaching a specified location 
otherwise out-of-range. The programmer may code an indirect address. With two-word 
instructions, indirect addressing is limited to four levels. Type 2 instructions cannot be 


indexed. 
Examples 

LDAI 19 Load A register with the value 
19. The value is coded in 
the second word of the instruction. 

JMP THERE Unconditionally jump to the 
instruction with the label 
THERE. 

JXNZ* SM lf the X register is not zero, 
jump to the instruction whose 
address ts contained in location 
SM (may be multi-leveled). 

XAZ IMP lf the A register is zero, 


execute the instruction at 

location IMP. In either case, 
control passes to the instruction 
following XAZ. 


3.3 TYPE 3 INSTRUCTIONS 


An assembler type 3 instruction occupies two consecutive computer words and is memory- 
addressing. It differs from an assembler type 2 instruction in that the variable field contains 


two expressions instead of one. 


Assembler type 3 instructicns are: 


Jump JIF Jump if condition(s) met 
BT Jump if bit condition met 
Jump-and-Mark JIFM Jump and mark if condition(s) met 
Execution XIF Execute if condition(s) met 
1/0 SEN Program sense and jump if true 
IME Input to memory 
OME Output from memory 
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The format of type 3 instructions is as follows: 


Operation Variable 


XXXX code,address Direct addressing 
yyyy* code,address Indirect addressing 
yyyy - code,(address)* 
where: 
XXXX is any type 3 instruction mnemonic 
yyyy is any type 3 instruction mnemonic except 
IME or OME 
code is a condition code (see below) 
address is an address expression 


indirect addressing is specified by an asterisk after the mnemonic or after a variable field 
expression in parentheses as described for the type 1 instructions. Note that IME and OME 


cannot specify indirect addressing. 


The code parameter entries are described in detail below. 


JIF, JIFM, and XIF Instructions 


For the JIF, JIFM, and XIF instructions, the expression code specifies the conditions required 
for the jump, jump-and-mark, or execution. The conditions are summarized in table 3-3; they 
are described in detail in the system handbook. Multiple conditions can be specified by 


setting additional bits. 


Table 3-3. JIF/JIFM/XIF Code Conditions 


Variable Field 


Jump/Execute if: 


Overflow indicator is set. 


A register contents are positive. 
A register contents are negative. 
NOT test of specified conditions. 


A register contents are zero. 


B register contents are zero. 


X register contents are zero. 
SENSE switch 1 is set. 
SENSE switch 2 is set. 
SENSE switch 3 is set. 
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BT Instruction 


For the BT instruction, the expression code is a 6-bit value that specifies the register and bit 


to be tested, in the form: 
4 3 21 0 


5 
z"z[b "bbb 
where: 


zz = 00 Specified bit in A register is 1 
= 01 Specified bit in B register is 1 
= 10 Specified bit in A register is 0 
= 11 Specified bit in B register is 0 


bbbb specifies the bit to be tested, from bit 


O (low-order bit) to bit 15 (high-order 
bit) 


SEN Instruction 


For the SEN instruction, the expression code is a 9-bit value that specifies the device address 
and I/O function, in the form: 


8 7 6 5 43 2 1 0 


where: 
q is a line number (0 to 7) 
da is the device address 


Standard device addresses are listed in section 3.4. 


IME and OME Instructions 


For IME and OME instructions, the expression code is the device address. 


Examples 


JIF 0222,ALFA In this example, the next 
instruction is taken from 
symbolic address ALFA if the 
A register contains a positive 
number (0002), the B register 
contains zero (0020), and 
SENSE switch 2 is set (0200); 
i.e., 0002 + 0020 + 0200 = 
0222. 
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ADDR 


BT 


SEN 
JMP 


OME 


INSTRUCTION SUMMARY 


056,ADDR In this example the next instruction 


from symbolic address ADDR is fetched 


if bit 14 of the A register contents 


is zero. 
0101,ADDR In this example, the next instruction 
*-2 is fetched from symbolic address ADDR 


if the write register of the Teletype 


is ready; OME is executed, which outputs 


the data in symbolic address LOC to 
01,LOC the Teletype. Otherwise, the next 


instruction in sequence (JMP) is executed, 


which returns the program io 


command. 


3.4 TYPE 4 INSTRUCTIONS 


the SEN 


An assembler type 4 instruction occupies one computer word and does not address memory. 
These instructions take none or a single variable operand. 


Assembler type 4 instructions are: 


Register Transfer 


Register Modification 


Control 


no 
operand 


TAB Transfer A register to B register 
TAX Transfer A register to X register 
TBA Transfer B register to A register 
TBX Transfer B register to X register 
TXA Transfer X register to A register 
TXB Transfer X register to B register 
TZA Transfer zeros to A register (clear A) 
TZB Transfer zeros to B register (clear B) 
TZX Transfer zeros to X register (clear X) 
TSA Transfer switches to A register 

IAR Increment A register 

IBR Increment B register 

IXR Increment X register 

DAR Decrement A register 

DBR Decrement B register 

DXR Decrement X register 

CPA Complement A register 

CPB Complement B register 

CPX Complement X register 

AOFA Increment A register if overflow set 
AOFB Increment B register if overflow set 
AOFX increment X register if overflow set 
SOFA Decrement A register if overflow set 
SOFB Decrement B register if overflow set 
SOFX Decrement X register if overflow set 
NOP No operation 

ROF Reset overflow indicator 

SOF Set overflow indicator 

HLT Halt 
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Shift/Rotation ASRA Arithmetic shift right A register 
ASRB Arithmetic shift right B register 
ASLA Arithmetic shift left A register 

operand ASLB Arithmetic shift left B register 

LASR Long arithmetic shift right 
LASL Long arithmetic shift left 
LSRA Logical shift right A register 
LSRB Logical shift right B register 
LRLA Logical rotation left A register 
LRLB Logical rotation left B register 
LLSR Long logical shift right 


LLRL Long logical rotation left 
Combined Register 
Transfer/Modification MERG Merge source to destination registers 
INCR Increment source to destination registers 
DECR Decrement source to destination registers 
COMP Complement source to destination registers 
ZERO Zero (clear) registers. 
1/0 EXC External control 
SEL External control 
EXC2 Auxiliary external control 
SEL2 Auxiliary external control 
CIA Clear and input to A register 
CIB Clear and input to B register 
CIAB Clear and input to A and B registers 
INA Input to A register 
INB Input to B register 
INAB Input to A and B registers 
OAR Output from A register 
OBR Output from B register 
OAB Output from A and B registers 


The format of type 4 instructions appears as follows: 


Operation Variable 


XXXX No variable field 
yyyy expression 
where: 

XXXX is any of the register transfer, register 
modification, or control instructions 
(except HLT) listed above. These instruc- 
tions take no operand. 

yyyy is any of the remaining instructions 
listed above. Theses instructions take 
one operand. 

expression is an expression value 


The expression value is described below for each group that uses it. 
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HLT Instruction 


The HLT variable field expression is optional; if present, it becomes the coded value of the 
instruction (otherwise zero). The HLT number can be displayed from the | register whenever a 
halt occurs to determine which halt was reached. 


Shift Instructions 


For the shift instructions, the variable field expression is the shift count (31 maximum). 


Combined Register Transfer/Modification Instructions 


For the combined register transfer/modification instructions, the variable field expression is a 
number of the form: 


Oxsd 


composed as shown below: 


Xx 
er ae 


0 = ad = = A reg 
unconditionally 1 = B reg 
1 = execute if OF is set 1 = X reg 
A reg 
= B reg 
= X reg 


For the ZERO instruction, the code must be of the form '’0x0d"’. 


1/O Instructions 


For EXC, SEL, EXC2, and SEL2, the expression specifies the |/O function and the device 
address in the form: 


o..-7 ~ 6.5 4S 2? 1 OD 
| f | da | 
where: 


f is the control function 


da__is the device address 


INSTRUCTION SUMMARY 


For the remainder of the |/O instructions in this group, the expression is the device address 
only (the 1/0 function being specified by the mnemonic). 


Examples 


HLT 066 Codes an instruction of the 
operand value that may be displayed 
when a halt at this location 


occurs. 
ASLA 1 Arithmetic left shift A register 
1 bit (equivalent to multiplying 
by 2). 
COMP 035 Unconditionally takes the 


inclusive OR and complements 
the contents of the A (0010) 
and B (0020) registers, and 
places the result in the A 
(0001) and X (0004) registers. 
Note that if bit 8 were one 
in the operand, the instruction 
would execute only if the 
overflow indicator is set. 


CIB 030 Clears the B register and loads 
it from the peripheral specified 
by device address 030. 


Standard device addresses are given in table 3-4. 
NOTE 


SEL/SEL2 are identical to EXC/EXC2 instructions. 
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Table 3-4. Standard Device Addresses 


Class Code Option or Peripheral 


00-07 01-07 Teletype or CRT device 
010-017 010-013 Magnetic tape unit 
014 Fixed-head rotating memory 
015 Movable-head rotating memory 
016-017 Movable-head rotating memory 
020-027 020,021 First BIC 
022,023 Second BIC 
024,025 Third BIC 
026,027 Fourth BIC 
030-037 030 Card reader 
031 Card punch 
032 Digital plotter 
033 Electrostatic plotter 
034 Second paper tape system 
035,036 Line printer 
037 First paper tape system 
040-047 PIM 
All PIM enable/disable 
MP/PARITY 
RTC 
050-057 050-053 Special applications, and 
Digital-to-analog converter 
through 
054-057 Analog system 
060-067 060-067 Digital 1/O controller, or 
Buffered !/O controller 
070-077 070-073 Data communications system 


074-076 


077 


Relay |/O controller, or 
Special applications 
Computer contro! panel 


3.5 TYPE 5 INSTRUCTIONS 
An assembler type 5 instruction occupies two consecutive computer words and is memory- 


addressing. All of these instructions have indirect addressing as an option. Most can be 
preindexed or postindexed. 
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Assembler type 5 instructions are: 


Extended Load/Store i.DAE 
DBE 
.DXE 
STAE 
STBE 
STXE 
Arithmetic ADDE 
SUBE 
MULE 
DIVE 
INRE 
Logical ANAE 
ORAE 
FRAE 
Jump IJMP 
JSR 
SRE 


Load A register extended 

Load B register extended 

Load X register extended 

Store A register extended 

Store B register extended 

Store X register extended 

Add memory to A register extended 

Subtract memory from A register extended 
Multiply extended 

Divide extended 

Increment memory extended 

AND memory and A register extended 
Inclusive OR memory and A register extended 
Exclusive OR memory and A register extended 
Indexed jump 

Jump and set return in index register 

Skip if register equals memory 


These instructions have the following formats: 


Operation Variable 
XXXX address,!,post Optional indexed 
addressing 
XXXX* address,i,post Indirect addressing 
or 
XXXX (address)*,i, post 
where: 

address is an address expression 

i if present, is an index specification, 
described further below 

post if present, is a postindex specification 


for ail extended addressing instructions. 


Indirect addressing is specified by an asterisk after the mnemonic or after a variable field 


expression in parentheses as described for the type 1 instructions. 


Preindexing is specified as described for the type 1 instructions. Note that IJMP and SRE 


cannot be preindexed. 


Postindexing is specified by three expressions in the variable field. The first expression is the 
data address, the second specifies the indexing register (X register = 1, and B register = 2), 
and the third is logically ORed with the instruction word to set bit 7 (which specifies 
postindexing). The assembler does not check the validity of the third expression; thus, the 
value 0200 should always be used. There is no purpose to postindexing unless indirect 


addressing is involved. 
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Variations in the interpretation of the variable field entries are discussed below. 


Extended Instructions 


For extended instructions, the variable field may contain one operand (direct addressing), two 
operands (preindexing), or three operands (postindexing). The instructions may also include 
indirect addressing. 


address Direct addressing 
or 

address, i Preindexed addressing 
or 

address,i,0200 Postindexed addressing 


IJMP Instruction 


The IJMP instruction may have direct, indirect, and postindexed addressing, i.e., variables of: 


address Direct addressing 
or 
address,i Postindexed addressing 


\JMP cannot be preindexed. 


JSR Instruction 


The JSR instruction, like IJMP, is not preindexed, nor is it postindexed. A variable field of the 
form: 


address, i 


is used to specify the jump address and the index register into which the return address is to 
be placed. 


SRE Instruction 


For the SRE instruction, the first expression in the variable field is the data address, the 
second specifies the type of addressing, and the third is logically ORed with the instruction 
word to control bits 3-5 to specify the register to be compared. The format may be illustrated 
as: 


address,t,reg 
where: 


address is the memory location to be compared 
to the specified register 
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t 
reg 
Examples: 
LDAE* 
LIMP 
JSR 
SRE 


specifies the type of addressing and may 
be any of the following: 


= ] index with X register 
= 2 index with B register 
= 7 not indexed 


is a register code of the register to be 
compared, as follows: 


= O10 A register 
= 020 6B register 
= 040 X register 


ADDR,2,0200 Loads the A register extended, 
indirect and postindexed with 
the B register. 


GO, 1 Indirect jump through location 
GO, postindexed by the X 
register. 

MOM, 2 Jump to location MOM and set 


return in B register. 


ADDR,7,020 Compares the contents of the 
B register with the directly 
addressed word at ADDR, and, 
if equal, skips the next two 
locations 


3.6 MULTIPLE REGISTER INSTRUCTIONS 


It should be noted that from the earliest Sperry Univac 620 software, the assembler syntax 
uses the convention that the X register is index register 1 and the B register is index register 2, 
However, the V70 emulation microprograms use hardware register R1 for the B register and 
hardware register R2 for the X register. The VORTEX DAS Assemblers resolve this by 
mapping references to register R1 into references to hardware register R2 and vice versa. 
Thus, for V70 series instructions, references to the X register generate instructions 
referencing hardware register R2 (X register). Since the programmer is usually indifferent to 
the hardware register number assigned the X and B registers (except possibly a diagnostic 
programmer), this should cause no programming problems. If a diagnostic programmer 
does want to reference a particular hardware register, the register designation in his 


assembly statements should be written as follows: 


a. Toreference register KO (A), write 0. 
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b. Toreference register R1 (B), write 2. 

c. Toreference register R2 (X), write 1. 

d. Toreference registers R3 through R7, write 3 through 7, respectively. 
NOTE 


The multiple register instructions generally require more time for execution; 
therefore, the standard instruction should be used whenever possible. 


3.6.1 Register-To-Memory Instructions 


Assembler mnemonics for the register-to-memory instructions are: 


AD Add 
LD Load 
SB Subtract 
ST Store 
Example 
LD, 0 0300,3 Register RO is loaded with 


the contents of the memory 
address specified by the sum 
of 0300 and the contents of 
register R3. Thus, if R3 
contains 0200, the operand 
for this instruction is in 
memory address 0500. 


3.6.2 Byte Instructions 
Assembler mnemonics for the byte instructions are: 


LBT Load Byte 
SBT Store Byte 


Example 


SBT 0200,3 The contents of the right byte 
of register RO are stored at 
the address specified by the 
‘sum of 0200 and the contents 
of register R3 (shifted right 
one bit). Thus, if R3 contains 
041, the operand is stored in 
the right byte at address 0220. 
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3.6.3 Jump-If Instructions 
Assembler mnemonics for the jump-if instructions are: 


JDNZ Jump If Double-Precision Register Not Zero 


JDZ Jump |f Double-Precision Register Zero 
JN Jump If Register Negative 
JNZ Jump If Register Not Zero 
JP Jump If Register Positive 
JZ Jump If Register Zero 
Example 
JZ,3 ADDR The program jumps to the symbolic 


address ADDR if register R3 
contains zero. If register R3 
does not contain zero, the next 
instruction in sequence is 
executed. 


3.6.4 Double-Precision Instructions 
Assembler mnemonics for the double-precision instructions are: 


DADD Double Add 


DAN Double AND 

DER Double Exclusive OR 
DLD Double Load 

DOR Double OR 

DST Double Store 


DSUB Double Subtract 


Examples 
DST,4 0200 The contents of double-precision 
register R4-R5 are stored at 
the two consecutive memory 
locations starting at address 
0200. 


DST,0 0200 Same as above except register 
RO-R1 contents are stored. 


3.6.5 Immediate Instructions 


Assembler mnemonics for the immediate instructions are: 


AD! Add Immediate 
LDI Load Immediate 


3-18 


INSTRUCTION SUMMARY 


Example 
ADI,5 0642 The immediate operand value 


of 0642 is added to the contents 
of register R5. 


3.6.6 Register-To-Register Instructions 

Assembler mnemonics for the register-to-register instructions are: 
ADR Add Registers 
SBR Subtract Registers 


T Transfer Registers 


Example 


T,3,4 The contents of register R3 
are transferred to register 
R4. 


3.6.7 Single Register Instructions 


Assembler mnemonics for the single register instructions are: 


COM Complement 
DEC Decrement 
INC Increment 
Example 
INC, 3 The contents of register R3 


are incremented by 1. 


3.7 V77-800 STANDARD EXTENSIONS 


The V77-800 standard extensions include instructions for rnoving and storing blocks of data. These 
extensions consist of the following seven instructions: 


Double Word Move (DMOVSD,DMOVXD,DMOVSX,DMOVXX). 
Registers Load (RGLD) 

Registers Store (RGST) 

Decrement register and Jurmp (DJP) 

Block Move (BMOVW) 

Store Words (STWRDS) 

Store Bytes (STBYTS) 
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3.7.1 Double Word Move Instruction 


This instruction can be used with or without indexed addressing as shown by the following: 


@ Double Word Move (DMOVSD). - Neither the source nor the destination addresses are 
indexed. 


| Double Word Move (DMOVXD). - The source address is indexed by Register R2(X). 
| Double Word Move (DMOVSX). - The destination address is indexed by Register R2(X). 


a Double Word Move (DMOVXxX). - The source and destination address are indexed by 
Register R2(X). 


Each of the double word move instructions moves up to seven double words. 
The format for the double word move instructions is 


name,words,source,destination 


where 
name is one of the V77-800 standard extension assermbler mnemonics 
words is the number of double word(s) to be moved 
source is the address the double word(s) is/are located at 
destination is the address that the double word(s) will be rnoved to. 


Assembler mnemonics and the corresponding functions associated with the double word rove 
instruction are: 


DMOVSD Address indexing is not used. Moves double word(s) frorn the source 
address to the destination address. 


DMOVXD The source address is indexed by the R2(X) Register and the destination 
address is direct. 


DMOVSX The source address is direct and the destination address is indexed by the 
R2(X) Register. 


DMOVXX Both the source and destination address are indexed by the R2(X) Register. 
Example 1: 


DMOVSD 1, LAB1, LAB2 


This exarnple rnoves one double word from the source address (LAB1) to the destination address 
(LAB 2). 
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Example 2: 
DMOvVXD 3, LAB1, LAB2 
This example moves three double words with the source address (LAB1) indexed by the R2(X) 
Register. The destination address (LAB2) is not indexed by the R2(X) Register. 
3.7.2 Register Load and Register Store Instructions 
Assembler mnemonics for the Register Load and Register Store instructions are: 
) RGLD Registers Load; Direct or Indexed Addressing 
a RGST Registers Store; Direct or Indexed Addressing 
The format for the Register Load and Register Store instruction is: 
name,address,index register 
where 
name is one of the assembler mnemonics 
address is the address to be indexed by the index register 
index register is the register whose contents are used to index the address 
Example 1: 
RGLD LAB1,R7 
Indexed; The address of LAB1 is indexed by R7. Registers O through 7 are loaded with the eight 
sequential words starting with the word at the augmented LAB1 address. 
Example 2: 
RGLD LAB1 
Direct; Registers O through 7 are loaded with the eight sequential words starting with the word at 
the address of LAB1. 
Example 3: 
RGST LAB1,R5 
Indexed; The contents of registers O through 7 are sequentially loaded into eight rnernory locations 
starting with the destination address indexed by R65. 
Example 4: 
RGST LAB1 ' 
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Direct; The contents of registers O through 7 are stored into a block of eight sequential memory 
locations starting with the address specified by LAB1. 


3.7.3 Decrement Register and Jump if the Initial Register Value is Not Negative 
(DJP) 


The assernbler mnemonic for this instruction is: 
DJP Decrement Register and Jump 
The forrnat for the Decrement Register and Jump is: 


name,index register,address 


where 
name is the ranemonic DJP 
index register is the index register from which one will be subtracted. If the value in 
the register ts non negative, the jump will occur. 
address is the address to which the jump may occur. 


if the jurnp does not occur the next instruction is executed. 
Example: 
DJP R7, LAB1 


This example subtracts one frorn the contents of R7 and, if the initial register value was not 
negative, jumps to the address of LAB1. 


3.7.4 Block Move, Store Words, and Store Bytes Instructions 


Assernbler rnanernonics for these instructions are: 
BMOVW Block Move 
STWRDS._ Store Words 
STBYTS Store Bytes 
The forrnat for the Block Move, Store Words, and Store Bytes instructions is: 
name 


where 


name is the ranernonic used 
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Example 1: 


BMOVW 


This example moves up to 32K words, fromm the address stored in RO to the destination address 
stored in R1. The block length is stored in R6 and must be a value greater than zero. 


Example 2: 

STBYTS 
This example stores the right byte of RO into a block of up to 32K bytes. The starting byte address of 
the mernory block is stored in R1. The block length, in bytes, is in R6. The block length stored in R6 
rnust be greater than zero. 
Example 3: 

STWRDS 
This example stores the word from RO into a block of up to 32K words. The initial address of the 


block is stored in R1. The block length of the block is stored in R6. The length of the block stored in R6 
rnust be greater than zero. 


323 


SECTION 4 
ASSEMBLER DIRECTIVES 


Assembler directives are requests to the assembler to perform certain operations during 
program assembly, just as machine instructions are used to request the computer to perform 
operations during program execution. 


Assembler directives are divided into the following functional groups: 


¢ Symbol definition 
* Instruction definition 
¢ Location counter control 
* Data definition 
* Memory reservation 
* Conditional assembly 
¢ Assembler control 
¢ Subroutine control 
* List and punch control 
* Program linkage 
* MOS1I/Ocontrol 
« VORTEX I/O control 

© Macro definition 


Table 4-1 lists the assembler directives by function and shows which directives are recognized 
by each assembler (DAS 8A and DAS MR). 


Assembler directives have the same general format as the computer instructions. In the 
following descriptions of the individual directives, the field format: 


Label Operation Variable 


is used, with the optional comment field being understood to follow the variable field when 
used. In cases where the variable field contains more than one item or expression, these are 
always separated by commas. Mandatory elements of the directive are in bold type, and 
optional items, in italic type. 
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Table 4-1. Directives Recognized by DAS Assemblers 


Function Directive DAS 8A - 


Symbol definition 


Instruction definition 


Location counter control 


Data definition 


Memory reservation 


Conditional assembly 


Assembler control 


Subroutine control 


List and punch control 


Program linkage 
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Table 4-1. Directives Recognized by DAS Assemblers (continued) 


Function Directive 


Macro definition 


MOS 1/0 control Applicable to DAS MR only; refer 
to the MOS Reference Manual. 


VORTEX I/O control Applicable to DAS MR only; refer 
to the VORTEX | or VORTEX I 
Reference Manual. 


VORTEX EXEC requests Applicable to DAS MR only; refer 
to the VORTEX | or VORTEX II 
Reference Manual. 


4.1 SYMBOL DEFINITION DIRECTIVES 


Symbol definition directives are used to assign values, specified in the variable field, to 
symbols specified in the label field. 


4.1.1 EQU Directive 


The EQU directive assigns a value to a symbol. Once assigned by an EQU directive, the value 
cannot be changed elsewhere in the program. 


This directive has the following format: 


Label Operation Variable 
symbol EQU expression 
where: 
symbol is a symbol which must be present. 
expression is any valid expression. 


The assembler places the symbol in the symbol table and assigns it the value of the 
expression. If the symbol has already been entered in the symbol table, DAS outputs an error 
message, and the expression replaces the value in the symbol table. If a symbol is used as the 
variable field expression, it must have been previously defined. 


Examples 
AID EQU 076000 AID is assigned the value 076000. 
X EQU i X is assigned the value l. 
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B EQU 2+10/5 B is assigned the value 4. 

ADDR EQU 0500 ADDR is assigned the (absolute) 
value 0500. 

ADRS EQU * ADRS is assigned the value 


of the current location counter 
(absolute or relocatable). 


BAM EQU SAD-*+1 BAM is assigned the expression 
evaluation (absolute or relocatable). 


NUM EQU 22 Double definition (*DD)--two 
. equate statements with the same 
label: should not appear in the 
. Same program. If they do, the 
NUM EQU 14 symbol table will contain the 
last value used. 


4.1.2 SET Directive 


The SET directive operates the same as EQU except that a symbol may be redefined without error. 


This directive has the following format: 


Label Operation Variable 
symbol SET expression 
where: 
symbol is a symbol which must be present. 
expression is any valid expression. 
Examples 
MOND SET 400 Assign value of 400 to MOND; 
. for subsequent statements, 
MOND has a value of 400. 
MOND SET 500 Assign value of 500 to MOND; 


for subsequent statements, 
MOND has a value of 500. 


Since symbols defined by the SET directive do not becorne part of the set of program entry points 
even if they are declared in a NAME directive (Section 4.10.1), the SET directive should not be used 
to assign a value to a variable which also appears in a NAME directive. 


For example, the staternent 


MOND SET 400 


and the staternent 
NAME MOND 


should not be used in the sarne program. 
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4.1.3 MAX Directive (DAS 8A Only) 


The MAX directive assigns the largest (maximum) algebraic value among a string of values to 
a symbol. 


This directive has the following format: 


Label Operation Variable 
symbol MAX expression, expression(s) 
where 
symbol is a symbol which must be present 
expression is any valid expression. The field may 
contain multiple expressions, separated 
by commas. ; 


The assembler assigns the largest algebraic value found among the expressions to the symbol. 
If a symbol is used as a variable field expression, it must have been previously defined. The 
value of the symbol may be redefined, if desired, via the SET directive. 


Examples 
MOST - MAX 1,2,3,4,5 Assigns the value 5 to MOST. 
SYM MAX HARRY, JOE, 3 Assigns to SYM the value of 


the symbol HARRY, the value 
of the symbol JOE, or 3, 
depending on which has the 
highest value. Both symbols 
must have been previously 
defined. 


4.1.4 MIN Directive (DAS 8A Only) 


The MIN directive assigns the smallest (minimum) algebraic value among a String of values to 
a symbol. 


This directive has the following format: 


Label Operation Variable 
symbol MIN expression, expression(s ) 
where: 
symbol is a symbol which must be present. 
expression is any valid expression. The field may 
contain multiple expressions, separated 
by commas. 


MIN is the same as MAX, except that the symbol is assigned the smallest algebraic value 
found among the expressions. 
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Examples 
TRV MIN 50000 Assigns the value 50000 to TRV. 
IN EQU 10 
IOB EQU 2+10/2*6 
MAPN MIN IN,10,10B Assigns the value 10 to MAPN 


(note that both label IN and 
constant 10 have this value). 


4.2 INSTRUCTION DEFINITION DIRECTIVE 


4.2.1 OPSY Directive 


The OPSY directive allows the user to optionally define his own mnemonic names for 
instructions. 


This directive has the following format: 


Label Operation Variable 
symbol OPSY mnemonic 
where: 
symbol is a symbol which must be present. 
mnemonic is any standard instruction mnemonic. 


The assembler makes the symbol a mnemonic name with the same definition as the variable 
field mnemonic. 


Examples 


CLA OPSY LDA Define CLA as equivalent to 
LDA 0300 LDA mnemonic; in subsequent 
CLA 0300 program statements, CLA and 
LDA may be used interchangeably 
as the "Load A register’’ 
instruction mnemonic. 


3123 OPSY JIF,0700 Invalid--variable field must 
contain only a standard instruction 
mnemonic. 


4.3 LOCATION COUNTER CONTROL DIRECTIVES 


Location counter contro! directives control the program location counter(s), which control 
memory area assignments and always point to the next available word. 


DAS 8A Location Counter Control. DAS 8A recognizes directives to modify or preset the values 
of any of its location counters (refer to table 2-1). In addition, up to eight other location 
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counters can be created, thus providing the possibility of constructing complex relocation and 
overlay programs within a single assembly. 


There are no user-created location counters at the beginning of an assembly. The assembler 
uses three location counters for program location assignment. Thus, IAOR (indirect pointer 
assignments) and LTOR (literal assignments) are always in used, as is a third counter used to 
assign locations to generated instructions and data. The blank location counter performs this 
task until the USE directive specifies another counter. 


In a straightforward program using only one location counter, the ORG and LOC directives 
completely control the counter. 


DAS MR Location Counter Control. DAS MR utilizes only one location counter. This location 
counter normally has a relocation bias of zero. DAS MR is most commonly used with an 
operating system and a relocating loader. Normally DAS MR programs are relocatable, and 
therefore location counter control should not be used. 


The ORG directive may be used in DAS MR to change the current location counter value 
(relocatable or absolute). The LOC directive may be used in DAS MR for assembly of programs 
that are to be moved under program control. Attempts to use ORG or LOC with DAS MR 


programs to be run under the operating system should be done with care so as not to overlay 
any system tasks. 


4.3.1 ORG Directive 
The ORG directive is used to specify the beginning location counter value. 


This directive has the following format: 


Label Operation _ Variable 
symbol ORG expression 
where: 
symbol is an optional user symbol. 
expression is an address expression. 


The assembler sets the location counter currently in use to the value of the expression. If a 
symbol is present in the label field, it is also set to the value of the expression (note that this 
is the current location counter value also). 


Any symbol used as the variable field expression must have been previously defined. 


For DAS MR, the address origin defaults to relocatable zero if no ORG directive is given. For 
DAS 8A, it defaults to absolute 04000 if no ORG directive is given. 
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Example 


The left-hand column below shows the value of the location counter at each program 
statement when origined as shown. 


Location 
Counter 
05000 ~ ORG 05000 Origin at 05000. 
05000 STRT LDA A 
05001 ADD Cc 
05002 SUB D 
05003 JMP AID 
05004 
05005 A DATA 5 
05006 c DATA 4 
05007 D DATA 3 

AID EQU 076000 

END 


4.3.2 LOC Directive 


The LOC directive is used to assemble a block of program code that is to be relocated during 
program execution. 


This directive has the following format: 


Label Operation Variable 
symbol LOC expression 
where: 
symbol is an optional user symbol. 
expression is an address expression. 


LOC is used if the data and instructions following this LOC address are to be moved to the 
LOC address by the object program before executing the moved block, i.e., to keep a block of 
data or instructions undisturbed by assembly. Data or instructions following LOC are 
generated as if an ORG directive had changed the current location counter value. However, 
this value is not actually changed. 


The location counter used for coding the block is specified by the expression. If a symbol is 
present in the label field, it is also set to the value of the expression. 


Any symbol used as a variable field expression must have been previously defined. LOC 
cannot be used in a relocatable program. 


Example 


The following program code illustrates the use of the LOC directive on the program counter 
values, as shown in the left-hand column. 
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Location 
Counter Contents 
0US000 UR Y3u000 Origin at 03000. 

0035000 O10091 A LUDA 1 Instructions assembled 
VYVS5NU1 Levu0e ADD 2 from 03000. 

VUS0Ue 1400035 SUs s 

VvuSU05 YULNON JMP C Last address must jump. 
VOS004 OUS014 . 

vusvus ENVA Eau * ENDA = 03005. 

QUugSuUYU 0 LOC 0500 Set assemble-origin at 0500. 
VOUSDU UOUVLVE VATA 1 These data or instructions 
OUVSU1L VOUVVDe VATA ¢ will be assembled for run- 
VUuvvsS0e vOUUUS UATA 3 ning at location 0500. They 
vdusos vudvous DATA 4 will be loaded into core at 
. nae . ; locations ENDA plus. You 
VOUSUS YUUDUDdS DATA i) ; 
00505 UUUOUS DATA 6 must move them to location 
¥ ie 0500 before running. 
UU005U6 QUoUU0!/ : DAIA 7 

vusuls L URKG CNUA+*=- 

vusuldy yvuuNly VATA & This is the next available 
UVSULD VvoUdLI Data y location after program B. 

END 


4.3.3 BEGI Directive (DAS 8A Only) 


The BEGI directive may be used in DAS 8A programs to define an initial value for any of the 
location counters. 


This directive has the following format: 


Label Operation _ Variable 
symbol BEGI expression 
where: | 
symbol is COMN, IAOR, LTOR, or SYOR (see table 2-1); 
or a user symbol to create a new location 
counter. 
expression is an address expression. 


BEGI creates a new location counter, or redefines the value of any location counter before the 
counter has been used. Up to eight user location counters may be created. BEGI gives the new 
or redefined location counter the value of the expression, but has no effect on the current 
location counter. 


BEGI is used to define initial values only. It cannot redefine the value of any location counter 
that has already been used for location assignment. 


Any symbol used as a variable field expression must have been previously defined. 


Examples 


Redefine standard counter IAOR 
to begin at location 050. 


ITAOR BEGI 050 
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LTOR BEGI 075 Redefine standard counter 
LTOR to begin at location 
075. 

UCNT BEGI 06500 Create a user location counter 
called UCNT. 


4.3.4 USE Directive (DAS 8A Only) 
The USE directive activates a specified location counter. 


This directive has the following format: 


Label Operation Variable 
(none) USE counter 
where: 
counter is a blank, COMN, or SYOR (see table 2-1); 
PREV; or a user-created location counter 
label. 


The USE directive causes the assembler to switch to the current value of the indicated 
location counter for assembly of subsequent source statements. If PREV is given, the 
previously used location counter is recalled, with the restriction that only the last-used 
counter can be so recalled. 


Examples 
USE COMN Switch to COMMON location counter. 
USE Switch to standard location counter. 
USE SYOR Switch to system location counter. 
LDA* * (Loads a system parameter.) 
USE COMN 
USE SYOR 
USE PREV Switch back to COMN location 

counter. 


4.4 DATA DEFINITION DIRECTIVES 


Data definition directives allow the user to create words of data as part of his source program. 


4.4.1 DATA Directive 
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The DATA directive generates one or more words of data that are output with the object 


program code. 


This directive has the following format: 


Label 
symbol 


where: 


symbol 


expression 


Operation 
DATA 


Variable 
expression, expression(s) 


if present, is assigned the value of 
the current location counter. 


is any valid expression. 


DATA generates data words with the values specified by the expression(s) in the variable field. 
DATA assigns the symbol, if used, to the memory address of the first generated word. In the 
- absence of a symbol, an unlabeled block of data is generated. 


Examples 


D DATA 
DATA 


DATA 


DATA 


DATA 


DATA 


FF 


"COMMENT ' 


1 


Creates data word of value 5 
and assigns the current location 
counter value to the symbol D. 


Creates data word of the value 
of symbol FF (absolute or 
relocatable). 


Creates 4 data words of 2 ASCII 
character bytes per word. 


Creates data word of the value 
of the expression (absolute or 
relocatable). 

Creates data word of value 3. 


Creates data word of value 1. 


Figure 4-1 shows a source listing to illustrate the object code generated by the above data 
expressions. The first column shows the location counter (beginning at relocatable zero), and 
the second column shows the object code generated. Refer to section 5 for a detailed 
description of the source listing. 
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009000 
Q05000 
005004 
005002 
005003 
005004 
005005 
008006 
005007 
005010 
005011 


000005 
005044 
144717 
146715 
142716 
152240 
04773 
nd000S 
000001 
917000 


{ ORG 
DATA 


05000 
5,FF,'COMMENT!, "5,142, 14 


-spPPrpPrpPTprPp>y> Pr bP 


LOA 0 


Figure 4-1. Sample DATA Directive Usage 


4.4.2 PZE Directive 


The PZE directive can be used to generate positive-only data words. 


This directive has the following format: 


Label Operation Variable 
symbol PZE expression, expression(s) 
where: 
symbol if present, is assigned the value of the 
current location counter. 
expression is any valid expression. 


PZE is similar to DATA except that the sign bit of the generated data word is always forced to 
zero (positive). 


Examples 


Figure 4-2 shows a source listing illustrating data words (in the second column) generated by 
the PZE directive. Note that the sign bit (high-order bit) is always zero, contrasted to the 
DATA directive generations. 
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‘ ORG 06000 
100 477777 2 DATA w1,72,7,1AB!, 0106612 
006001 177776 
006002 000007 
O06n03 140702 
006004 106612 
006005 077777 
006006 077776 
006007 900007 
006010 040702 

: nOn612 


3 PZE =1,°2,7,'AB', 0106612 


rPrrTrPprp rr > YP YP 


4 END | 


Figure 4-2. Sample PZE Directive Usage 


4.4.3 MZE Directive 
The MZE directive can be used to generate negative-only data words. 


This directive has the following format: 


Label Operation Variable 
symbol MZE expression, expression(s) 
where: 
symbol if present, is assigned the current location 
counter value. 
expression is any valid expression. 


MZE is similar to DATA except that the sign bit of the generated data word is always forced to 
one (negative). 


Examples 


Figure 4-3 shows a source listing illustrating the use of MZE. 


007000 
007000 1000014 
007991 10n000 
007002 100002 
007003 106642 


o7one 
2 MZE 1072, 06612 


>> Pp ED 


3 END 


Figure 4-3. Sample MZE Directive Usage 
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4.4.4 FORM Directive 


The FORM directive specifies the format of a bit configuration of a data word. 


This directive has the following format: 


Label 
symbol 
where: 
symbol 
term 


Variable 
term,term(s) 


Operation 
FORM 


is a user symbol. 


is an absolute expression. 


The symbol is the name of the format. The terms specify the length in bits of each field in the 
generated data word, where the sum of their values is from one to the number of bits in the 
computer word. 


FORM is ignored if there are any errors in the variable field, except that an error is flagged 
when a term cannot be represented in the number of bits specified when FORM is applied (by 
placing its name in the operation field of a symbolic source statement) to another statement. 
A FORM symbol can be redefined. 


Examples 


Figure 4-4 shows sample usage of the FORM directive. 


a. Without error: Label 
1 RYTE FORM 
2 8CD FORM 
3 PTAB FORM 
4 ABC FORM 
000000 H14701 A 5 ABC 
ONONNL 106612 A 4 BYTE 
b. With error: Label Operation 
QO0N00N2 AD0NOS A 7 PTAB 
aSZ 
x§Z 
8 END 


tn cnc RR eesti res 


Figure 4-4. Sample FORM Directive Usage 


4.5 MEMORY RESERVATION DIRECTIVES 


Operation Variable 


8,8 
4,4,4,4 
1,2,3,4 
6,2,8 
2xd,1,°A! 
0215,0212 


Variable 
2 8 4 r § 


Memory reservation directives control the reservation of memory addresses and areas. 
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4.5.1 BSS Directive 


The BSS directive is used to reserve a block of memory locations for use by the program 
during its execution. 


This directive has the following format: 


Label! Operation Variable 
symbol BSS expression 
where: 
symbol if present, is assigned the current location 
counter value. 
expression is an absolute expression. 


BSS reserves a block of memory addresses by increasing the value of the current location counter by 
the amount indicated by the expression. The symbol, if used, is assigned the value of the counter 
prior to such an increase, thus referencing the starting address of the reserved block. 


If the variable field expression value is zero, the symbol is assigned the next available address 
(i.e, BSS O = BSS 1). 


Examples 

B BSS 050 Reserve a block of 050 words 
and assign the beginning loca- 
tion address to B. On completion, 
the location counter will 
be at B+050. The locations 
can be accessed as B, B+1, 
B+2,..., B+047. 

MO BSS 1 These three statements reserve 

MP BSS 1 3 words of storage, each 

MQ BSS 1 separately labeled. 


4.5.2 BES Directive 
The BES directive, like BSS, is used to reserve a block of memory locations. 


This directive has the following format: 


Label Operation Variable 
symbol BES expression 


where: 
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symbol if present, is assigned the current location 
counter value. 


expression is an absolute expression. 


The BES directive is similar to BSS, except that if there is a symbol it is assigned to the 
address one less than the incremented location counter. 


If the variable field expression is zero, the symbol is assigned the last address used (i.e., BES 
O has no effect). 


Example 


B BES 050 Same as BSS above, except that 
the label B is assigned a 
value of the end of the 
block. Thus, the locations 
can be accessed as B-1, B-2, 
B-3,..., B-047. 


4.5.3 DUP Directive 
The DUP directive can be used to duplicate source statements input only once. 


This directive has the following format: 


Label Operation Variable 
symbol DUP n,m 
where: 
symbol if present, is assigned the current location 
counter value. 
n is a constant that specifies the duplication 
count. 
m if present, is a constant that specifies 


the source statement count for duplication. 
If omitted, it defaults to one. 


DUP duplicates source statements that follow the DUP directive. An n-only format duplicates 
the next source statement the number of times specified by n. An n,m format duplicates the 
next 1, 2, or 3 source statements (the number of which is specified by m) the number of times 
specified by n, which ms 3 and ng 32,767. If n or m is zero, it is treated as if it were a one. 


A DUP statement may not appear within the range of another DUP statement. The 
statement(s) being duplicated should not contain any labels, as the labels will be duplicated 
also and a '’double definition” (*DD) diagnostic will result. 
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Examples 

B DUP | 3 Duplicate the next statement 
ADD 3 (the ADD instruction) three 

c EQU * times. 

B DUP 2,2 Duplicate the next 2 statements 
ADD 3 (the ADD instructions) two 
ADD 4 times. 

c EQU * 


Complete source listings for these two examples are shown in figure 4-5. Note the 
duplications. 


Example 1 
004600 1 ORG 04000 
004000 A 2 A EQU * 
3 8 OUP 3 
004000 120003 A 4 ADD 3 
ON4001 120003 A 4 ADO 3 
004002 120003 A 4 ADO 3 
Q04003 A 8s ¢ EAU a 
6 END 


Example 2 
9000000 


900000 1209003 
000001 120004 


000002 120063 
000003 120004 
000004 


A OAaGWA GN 


Figure 4-5. Sample DUP Directive Usage 


4.6 CONDITIONAL ASSEMBLY DIRECTIVES 


Conditional assembly directives assemble portions of the program according to the conditions 
specified in the variable fields. 


4.6.1 IFT Directive 
The IFT directive assembles the next source statement if the specified relationships are true. 


This directive has the following format: 


Label Operation Variable 
(none) - IFT expression, expression(s) 


ASSEMBLER DIRECTIVES 


where: 
expression is an absolute expression 


IFT assembles the next source statement only if the first expression is jess than the second, 
and the second is less than or equal to the third, i.e.: 


IFT a for az# QO 
IFT a,,b for ax b 
IFT a,b,b for a< b 
IFT O,a,b for O< as b 


IFT examples are given in section 4.6.5. 


4.6.2 |IFF Directive 
The IFF directive assembles the next source statement if the specified relationships are false. 


This directive has the following format: 


Label Operation Variable 
(none) iFF expression, expression(s) 
where: 
expression is an absolute expression 


IFF is similar to {FT (IFT = true) except that IFF (IFF = false) is the logical complement of 
IFT, i.e.: 


IFF a fora = 0 
IFF a,,b fora = b 
IFF a,b,b for a2 b 
IFF 0,a,b for 02> a> b 


IFF examples are given in section 4.6.5. 


4.6.3 GOTO Directive 
The GOTO directive can be used to skip assembly of a block of source statements. 


This directive has the following format: 
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Label Operation Variable 
symbol 
symbol, 
integer 
(none) GOTO integer, 
absolute expression i 
: absolute expression, ee 
where: 
symbol is a user symbol 
integer is any integer 
absolute expression is an expression (e.g. of the form A = B+C-3) rem 


a comma following the variable field 
entry is used to control output listing. 


- GOTO usually follows an IFF or IFT directive. All source statements between the GOTO and the 
statement containing the symbol/integer in its label field are skipped, and the instruction so 
labeled is assembled next. GOTO cannot return to an earlier point in the program. 


If the symbol, integer, or arithmetic expression are not followed by a comma, the skipped 
instructions are listed. If the symbol, integer, or arithmetic instructions (containing a comrna after 
the variable field elernent) are used, the skipped instructions are not listed. This listing can also be 
suppressed by a SMRY directive (paragraph 4.9.3). 


The GOTO with the absolute expression applies only to DAS MR used with the VORTEX | and 
VORTEX II operating system. 


GOTO examples are given in section 4.6.5. 
4.6.4 CONT Directive 
The CONT directive may be used in conjunction with GOTO as the destination statement. 


This directive has the following format: 


Label Operation Variable 
ee CONT (none) 
integer 
where: 
symbol is a user symbol 
integer is any integer 


CONT provides a target for a previous GOTO directive. The symbol/constant is not entered in 
the assembler’s symbol table. 


CONT examples are given in section 4.6.5. 


4.6.5 NULL Directive 


The NULL directive may be used in conjunction with GOTO as the destination statement. 
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This directive has the following format: 


Label Operation Variable 
symbol NULL (none) 


NULL provides a target for a previous GOTO directive with the symbol entered in the symbol 
table. NULL has the same effect as a BSS directive with a blank variable field. 


Examples 


The sample program in figure 4-6 illustrates use of the conditional assembly directives. 


000022 A 1 NBIT EQU 18 
2 YF NAT Te#i6 
3 GoTo YYY 18 BITS 
4 un 
§ « $6 BIT INSTRUCTIONS 
6 IFF NBETa16 
? GOT. 123 16 AITS 
000000 A08000 A 8 YYY NOP 
Q & 
10 » £8 BIT INSTRUCTIONS 
iq 
Q000K! 12 493 NULL ENTER INTO SYMBOL TABLE 
13 345 CONT TGNQARE SYMBOL 
1A ENO 


Figure 4-6. Sample Conditional Assembly Directives Usage 


4.7 ASSEMBLER CONTROL DIRECTIVES 


Assembler control directives signal the end or continuance of an assembly. 


4.7.1 MORE Directive (DAS 8A Only) 


The MORE directive is used in DAS 8A assembly when the input medium does not hold all of 
the source statements at one time. 


This directive has the following format: 
Label Operation Variable 
(none) MORE (none) 


MORE halts the assembly process to allow additional source statements to be put in the input 
device. Assembly resumes when the RUN or START switch on the computer control panel is 
pressed. MORE is never listed. 
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4.7.2 END Directive 
The END directive signais the end of the source program. 


This directive has the following format: 


Label Operation Variable 
(none) END expression 
where: 
expression is an address expression 


END is the last source statement in the program. The expression is the execution address of 
the program after it has been loaded into the computer. A blank in the variable field yields an 
execution address of zero. 


4.8 SUBROUTINE CONTROL DIRECTIVES 


Subroutine control directives create closed subroutines (i.e., internal to the main program) 
and control their use. 


4.8.1 ENTR Directive 
The ENTR directive is the first statement in a closed subroutine. 


This directive has the following format: 


Label Operation Variable 
symbol ENTR (none) 
where: 
symbol is a user symbol which must be present. 


The symbol is used as the name of the subroutine when called. ENTR generates a linkage 
word of zero tn the object program. 


Example 


The following program listing illustrates use of the ENTR directive as the first statement of a 
closed subrot'tine. 


000802 900000 4 2 TY ENTR 

Q6O0aS 101103 A 3 SEN OL10%, 44 
OO0nHN4 BO00N7 FR 

ON0RAS GNLGAG A 4 JMP kw 2 
aqobanKe HO0G0S R 
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4.8.2 RETU* Directive 


The RETU* directive can be used to return from a closed subroutine. 


This directive has the following format: 


Label Operation Variable 
symbol RETU* expression 
where: 
symbol if present, is assigned the current location 
counter value. 
expression is an address expression 


RETU* returns from a closed subroutine, generating an unconditional indirect jump to the 
address indicated by the value of the expression. 


Example 


The following program listing illustrates use of the RETU* directive to return from a closed 
subroutine. 


200007 AQ8000 A 3 NOP 
000010 901000 A 6 RETUs TTYW 
900011 100002 R 

? END 


4.8.3 CALL Directive 
The CALL directive is used to call closed subroutines. 


This directive has the following format: 


Labe! Operation Variable 
symbol CALL name, parameter(s),error(s) 
where: 
symbol if present, is assigned the current location 
counter value. 
name is the symbolic name of the subroutine 


being called. 
parameters(s) if present, are one or more data parameters 


being passed to the subroutine, separated 
by commas. 
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if present, are one or more address 
expressions, separated by commas, that 
are to be used by the closed subroutine. 


error(s) 


CALL causes the program to jump and mark to the closed subroutine specified by name. The 
parameter list, if present, is available to the subroutine. The error return list, if present, 
provides the possibility of returning to jocations other than the statement following the CALL 


statement. 


Examples 


The sample program calls in figure 4-7 illustrate use of the CALL directive. 


Example 1 


000060 9902600 A 4 CALL TT YW 
000001 000002 R 
Example 2 

004006 1 ORG 64000 

904000 900000 A @ FUNC ENTR 
3 8 
4 » PUNC WILL HAVE ADORESS OF PARAMETER X 
S w WHEN CALLING THES SUBROUTINE, 
6 

004601 601000 A ? REYTUs FUNE 

OG8O62 £04900 A 

G & 

9 x 
19 «# 

004903 06020060 A 4% CALL. FUNC, X,Y¥*1, (ERR), (GOOF) «# 

004004 064900 A 

004008 o04alt A 

004006 AO4G13 A 

G04967 n04043 A 

004010 194014 4 
12 « 
43 w MASN BODY OF PROGRAM 
14 »# 

004611 900005 A 18 ¥ DATA 5 

0040492 00006 A 16 ¥ DATA 6 

004045 660747 A 17 ERR DATA OF 47 

004094 A00787 A 18 GOOF DATA 0727 

END 


see 


Figure 4-7. Sample CALL Directive Usage 
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4.9 LIST AND PUNCH CONTROL DIRECTIVES 


List and punch control directives control listing and punching during program assembly. They 
are operative only during the second pass of the assembler, when the object program and 


listings are produced. 


4.9.1 LIST Directive 


The LIST directive is used to resume generating a source listing after a list-inhibiting directive 
has been given. 


This directive has the following format: 


Label Operation _ Variable 

(none) LIST (none) 
LIST causes the assembler to start or resume output of a source program listing. The 
assembler normally outputs a list of the source statements. The LIST directive is used to bring 


_ the assembler back to this condition when the NLIS directive (section 4.9.2) has been issued 
to change the listing status. 


4.9.2 NLIS Directive 
The NLIS directive is used to inhibit the program listing. 


This directive has the following format: 


Label Operation Variable 
(none) NLIS (none) 


NLIS suppresses further listing of the program. 


4.9.3 SMRY Directive 
The SMRY directive may be used to inhibit listing of conditionally-skipped source statements. 


This directive has the following format: 


Label Operation — Variable 
(none) SMRY (none) 


SMRY suppresses the listing of source statements that have been skipped under control of the 
conditional assembly directives. 


4.9.4 DETL Directive 
The DETL directive is used to cancel the effect of the SMRY directive. 
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This directive has the following format: 


Label Operation Variable 
(none) DETL (none) 


DETL removes the effect of SMRY, i.e., causes listing of all source statements, including those 
skipped by conditional assembly directives. 


4.9.5 PUNC Directive (DAS 8A Only) 


The PUNC directive is used in DAS 8A programs to cancel the effect of the NPUN directive. 


This directive has the following format: 


Label Operation Variable 
(none) PUNC (none) 


PUNC causes the assembler to produce a paper tape punched with the object program. The 


assembler normally outputs such a tape. PUNC returns the assembler to this condition when 
the NPUN directive (section 4.9.6) changes the punching status. 


4.9.6 NPUN Directive (DAS 8A Only) 


The NPUN directive may be used to inhibit further punching of the object program to paper 
tape. 


This directive has the following format: 


Label Operation Variable 
(none) NPUN (none) 


NPUN suppresses further production of paper tape punched with the object program. 


4.9.7 SPAC Directive 
The SPAC directive can be used to insert blank lines in the source listing. 


This directive has the following format: 


Label Operation Variable 
(none) SPAC (none) 


SPAC causes the listing device to skip a line. The SPAC directive itself is not listed. 


4.9.8 EJEC Directive 


The EJEC directive causes a page eject. 
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This directive has the following format: 


Label Operation Variable 
(none) EJEC (none) 


EJEC causes the listing device to move to the next top of form. The EJEC directive itself is not 
listed. 


4.10 PROGRAM LINKAGE DIRECTIVES 


Program linkage directives establish and control links among programs that have been 
assembled separately but are to be loaded and executed together. 


4.10.1 NAME Directive 


The NAME directive establishes linkage definition points among separately assembled 
programs. 


This directive has the following format: 


Label Operation Variable 
(none) NAME symbol, symbol(s) 
where: 
symbol is any symbolic expression 


With the NAME directive, each symbol can then be referenced by other programs. Each 
symbol also appears in the label field of a symbolic source statement in the body of the 
program to give it a value. Undefined NAME symbols cause error messages to be output. 


Examples 


NAME A Provide value of symbol A to 
other programs. 


NAME A,B Provide values of symbols A 
and B to other programs. 


NAME EX,WHY, ZEE Provide values of symbols 
EX, WHY, and ZEE to other 
programs. 


4.10.2 EXT Directive 


The EXT directive allows separately assembled programs to obtain the values of symbols 
defined in other program NAME directives. 


This directive has the following format: 
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Label Operation Variable 
label EXT symbol(s) 
where: 
symbol is a value to be obtained from other 
programs. 


In linking separately assembled programs, EXT declares each symbol not defined within the 
current program. Each symbol, in both the label and variable fields, is output to the 
relocatable loader with the address of the last reference to the symbol for the loader to supply 
the value to the program when the value is known. 


lf a symbol is not defined within the current program and is not declared in an EXT directive, 
it is considered undefined and causes an error message output. !f a symbol is declared in EXT 
but not referenced within the current program, it is output to the loader for loading, but no 
linkage to this program is established. If a symbol is both defined in the program and 
declared to be external, the EXT declaration is ignored. 


Examples 
EXT AY Declare AY to be external. 


BEG EXT BE, SEE Declare BE and SEE to be external: 
the value of BEG is passed 
to the loader. 


EXT DEE, EE,FF,GEE Declare the indicated symbols 
to be external. 


4.10.3 COMN Directive 
The COMN directive defines an area in blank common for use at execution time. 


This directive has the following format: 


Label Operation Variable 
symbol COMN expression 
where: 
symbol if present, is assigned the current location 
counter value 
expression is an absolute expression 


CCMN allows an assembler program to reference the same blank common area as a 
FORTRAN program. The common area is cumulative for each use of COMN, i.e., the first 
COMN defines the base area of the blank common, the second COMN defines an area to be 
added to the already established base, etc. 
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Examples 
AAA COMN 3 Allocate 3 words of common, the 
first word addressable by AAA. 
COMN 6*2 Allocate 12 words of common; if 
following the above statement, 
this would be the fourth through 
sixteenth common locations. 
BBB COMN 9 Allocate 9 words of common, the 


first word addressable by BBB; 
if following the above 2 state- 
ments, this would be the 
seventeenth through twenty-fifth 
locations of common. 


4.11 MACRO DEFINITION DIRECTIVES (DAS MR ONLY) 


The V70 series macro language is an extension of the V70 assembler language. It provides a 
convenient way to generate a desired sequence of assembly language statements many 
times in one or more programs. The macro definition is written only once, and asingle macro 
call statement used each time a programmer wants to generate the desired sequence of 
statements. This method simplifies the coding of programs, reduces the chance of 
programming errors, and ensures that standard sequences of statements are used to 


accomplish desired functions. 


Every defined macro is associated with a four- or six-character symbolic name. The defined 
macro is called when this name appears in the operation field of an assembler source 
statement. 


A Macro Definition is a set of statements that provides the assembler with the symbolic name 
of the macro and the sequence of statements that is to be generated when the macro is 
called. Macro definitions start with the MAC directive and are ended with the EMAC directive. 


The macro is the assembly equivalent of the execution subroutine. It is defined once and can 
then be ’’called’”’ from the program. The macro is an algorithmic statement of a process that 
can vary according to the arguments supplied. It is assembled with the resultant data 
inserted into the program at each point of reference, whereas the subroutine executed during 
execution time appears but once in a program. 


4.11.1 MAC Directive (DAS MR Only) 


The MAC directive is used to mark the beginning of a macro definition and specify the name 
of the macro. 


This directive has the following format: 


Label Operation Variable 
symbol MAC (none) 
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MAC introduces a macro definition. The symbol is the name of the macro. 


The use of the MAC directive is shown in the program example given in section 4.11.3. 


4.11.2 EMAC Directive (DAS MR Only) 
The EMAC directive is used to signal the end of a macro. 


This directive has the following format: 


Label Operation Variable 
(none) EMAC (none) 


EMAC terminates the definition of a macro. 


The use of the EMAC directive is shown in the program example given in section 4.11.3. 


4.11.3 Macro Calls 


A Macro Call statement is a source program statement with the symbolic name of a defined 
macro written in the operation field. The assembler generates a sequence of assembly 
language statements for each occurrence of the same macro call statement. The generated 
statements are then processed like any other assembly langauge statement. 


A macro is called by the appearance of its name in the operation field of a source statement. 
The variable field of this statement contains expression(s) P(1), P(2).,,,P(n), which are then 
processed with the values in the table being substituted for the respective values of the 
expressions in the source statement variable field. For example, if the variable field of the 
symbolic source statement contains: 


2,B,9 +8, =63 

then within the generated macro P(1)=2, P(2)=the value of B, P(3)=17, and P(4) is the 
address of the value 63. All terms and expressions within the macro-referencing symbolic 
source statement parameter list are evaluated prior to calling the macro. 

lf the label field of such a source statement contains a symbol, the symbol is assigned the 
value and relocatability of the location counter at the time the macro is called but before data 
generation. 

A macro definition can contain references to machine instruction mnemonics or to assembler 
directives other than DUP. Macros can be nested within macros to a depth limited only by the 


available memory at assembly time. 


Figure 4-8 illustrates the use of macros. 
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1 SENSE mac 
2 SEN P(49,#44 \ Macro 
3 IMP wad Definition 
4 EMAC 
§ SENSE 0204 — Macro Call 
0600000 104204 A 
000001 nann04d R Macro — 
090902 H01000 A Expansion 
0090003 000000 R 
O00004 4f2501 A 6 CIA 04 
? SENSE 01014 
ON0NNS 1404101 A 
000006 O00011 R 
000MM? NO1000 A 
000016 000005 R 
O00NG4 1031204 A 8 QAR 04 
9 END 


Figure 4-8. Sample Macro Usage 


P(O) can also be accessed by a normal call. P(O) is the first entry in the table formed by the 
assembler and contains the number of entries in that table. Figure 4-9 shows the output 
listing obtained by calling P(0). 


000001 OO00000A 


000002 OOO001A 
000003 000002A 
000004 000003A 
000005 OOO0004A 
000006 OO00005A 


—“WO ON DU FWN a= 


Figure 4-9. Output Listing Obtained by Calling P(0) 


4.12 NOTE DIRECTIVE (DAS MR WITH VORTEX | AND VORTEX II) 


The NOTE directive generates a listing when it is encountered in a macro expansion, unlike all 
other instructions or pseudo operations. 


This directive has the following forrnat: 


Label Operation Variable 
Symbol NOTE comment 
Integer 


The label is entered in the assernbler’s symbol table. 
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4.13 FLOWCHART DIRECTIVE (DAS MR ONLY) 
4.13.1 FLOW Directive (DAS MR Only) 


FLOW is used to generate flowchart boxes. 


The sequence of lines printed by this directive are: 


w@ A blank line 

& Arow of asterisks 

@ The FLOW directive line 
a A bottom row of asterisks 
@ A blank line 


Box type, label and branches are placed in the appropriate places in the flowchart box borders 
All labels and symbols used with the FLOW directive are not considered as part of the prograri 
symbol table and can not be used either for any program label functions or as operands in other 


parts of the program. The 2 blank lines and asterisk lines generated are not counted as assernbly 
lines by the assernbler. 


Figure 4-10 contains a sample of FLOW directive usage. 


PROGRAM OUTPUT FLOWCHART FORMATS 


Print Position Contents 
Top Box 1-29 blank 
30 asterisk 
31-32 flow type 
33-40 asterisks 
41-45 optional flow label 
46-69 asterisks 
Botton Box 1-29 blank 
30 asterisk 
31-36 optional non-contiguous flow or 


decision right syrnbol (based on decision 
response, yes or no) 


37-40 asterisks 

41-46 optional decision non-contiguous 
symbol 

47-69 asterisks 
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PROGRAM INPUT FORMAT 


Columns Contents 
1-6 optional flowchart box label 
7 blank 
8-12 FLOW, 
13-14 flowchart type: 
EN = entry 
EX = exit 


PR = procedure 

SU = subroutine 

DY = decision, yes branch to right 
DN = decision, no branch to right 
10 = 1/0 process 

CO = continuation flow 


15 blank 
16-28 optional branch labels of the form: 
LABEL1,LABEL2 
where: 


LABEL1 = for DY or DN the branch on specified 
condition; else for non-contiguous flow. 


LABEL2 = for DY or DN to specify non-contiguous 


flow 
29 blank 
30 asterisk 
31 blank 
32-67 comment line for flowchart box. If current flow is 


a subroutine, the subroutine narne begins in 
colurnn 32 and continues for up to 6 characters. 
The name delimiter is a comma. 


68 cormma if comments continue into next line 
otherwise blank 


69 asterisk 
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000000 
000001 


000002 
000003 


000004 
000005 


000006 
000007 


000010 
000011 


000012 
000013 


000000 
000000 


000000 
000000 


000000 
000000 


000000 
000000 


000000 
000000 


000000 
000000 


ENTRY NAMES 


EXTERNAL NAMES 
SYMBOLS 


1 
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2 * DEMONSTRATION OF THE DAS MR 'FLOW' FLOWCHART DIRECTIVE 


3 


* 


4 SYMBl1 FLOW,EN 


20 


21 
22 


23 


24 


LAB2 


LAB3 


DATA 0 
DATA 0 
FLOW, SU 

DATA 0 
DATA 0 


FLOW,DY LAB2 


DATA 0 
DATA 0 


FLOW, DN LAB2,LAB3 
FLOW, CO 


DATA 0 
DATA 0 
FLOW, PR 

DATA 0 
DATA 0 


FLOW, 1IO,LAB1 


DATA 0 
DATA 0 
FLOW , EX 
END 


ZERO ERRORS ASSEMBLY COMPLETE 


KRENEK RARKEK CY MB] RAK A KEKE EAEKEKEEAKK AHR KE KK 


* ENTRY BOX = 
KIRK KEKE RIKKI KKK KKK KEKE KE KE RHR KK 


RG RARER KEKE KKEEKKEKREKKKKK KEK KKK 


* SUBR, SUBROUTINE BOX x 
KKK KKK EKER RRR RRR ERK 


* REKKKKEEKAKKEKKEEKKKEKKKKKKEKKKKRKKKK KKK KKK 
DY 


* DECISION WITH BRANCH ON YES RESPONSE * 
* ABQ BRR KK RRR OR RR RR RK RR RR RK 


KONA AERA K ARK K KEE KEKARE RE RKEKRKRKKAEEK KR KKK 


* DECISION WITH BRANCH ON NO RESPONSE * 


* AND NONCONTIGUOUS FLOW ON YES = 
*LABQ** ERE RL A BGR RRA KARE RAR KARE RK RR KR KKK 


FPREKKKREKEK, AQADEKRKKKEREKKEREKKKRK KKK KK 


* PROCESS TYPE BOX * 
KAEKKKHEKKKREKEKKEKKKKKRKKRKKEKKaEKKKKKKRKKKKEKKRKK 


RIL QRRAKERKKE, ARBRE KKK KKK KEKEKKKEKEREK KKK 


* NONCONTIGUOUS FLOW x 
KLABLE REAR ARR KEARKKKKEKKKEKKEKERKEE RK KKK KEKE 


RD YK aK KERR KKK RK KERR EER EKER EI K KEK 
EX 


* EXIT BOX * 
KI RIOR KOR IR RK IK TKR TKR IK II RRA KK IK IK 


Figure 4-10. Sample FLOW Directive Usage (DAS MR Only) 
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SECTION 5 
OPERATING THE ASSEMBLER 


DAS MR and DAS 8A are two-pass assemblers that may be scheduled by job central 
directives. Assembler processing during the two passes is described in section 5.1. 
Operation of DAS MR under VORTEX I/VORTEX II is described in section 5.2, followed by 
operation descriptions of DAS MR under MOS, as stand-alone, and of DAS BA (also stand- 
alone). 


5.1 ASSEMBLER PROCESSING 


This section describes the general features of DAS assembler processing. Specific operating 
procedures and output listing examples for various DAS/operating system combinations are 
given in section 5.2. 


5.1.1 Assembler Input Media 


The source program may be input to the assembler on punched cards, paper tape, or any 
other source input medium. Details regarding source statement field placement are given 
below. 


Fixed Format. Fixed format, normally used with punched cards, used as input to the DAS 
assemblers contains four fields corresponding to the instruction and directive fields: 


a. The label field is in columns 1 through 6. Its use is governed by the requirements of the 
instruction or directive. 


b. The operation field is in columns 8 through 14. It contains the instruction or directive 
mnemonic. Indirect addressing is specified by an asterisk following the mnemonic. 


c. The variable field begins in column 16 and ends with the first blank that is not part of a 
character string. Its use depends on the instruction or directive. If two or more subfields 
are present, they are separated by commas. 


d. The comment field fills the remainder of the card. If the variable field is blank, the 
comment field begins in column 17. 


An asterisk in column 1 indicates that the entire card contains a comment. 


The fixed format is shown in figure 5-1. Note that columns 7 and 15 are always unpunched 
(blank). 


Free Format. Free format can be used with any media but is normally used with paper tape. Free 
format used as input to the DAS assemblers contains source staternents of up to 80 characters 
each (not including the carriage return and line feed characters). Each punched staternent contains 
four fields corresponding to the instruction and directive fields. The label, operation and variable 
fields are separated by commas or blanks, and the cormment field starts after the first variable field 
blank that is not part of a character string. Each statement is terminated by a carriage return (CR) 


followed by a line feed (LF). a 


cg 


Aseuiwing juewacelg play “[-G ansi4 


LABEL 


LABEL 


LABEL 


LABEL 


* The comment can start anywhere after a blank following the 
variable field. 


OPERATION ,COMMENT 


A. FIXED FORMAT (STANDARD COLUMNS) 


OPERATION VARIABLE COMMENT* IDENTIFICATION 
6 8 14 16 28 30 7273 80 
B. FIXED FORMAT (MINIMUM SPACING) 
OPERATION VARIABLE COMMENT 


7 spaces or less 


OPERATION COMMENT 


8 spaces or more 


C. FREE FORMAT (COMMAS FOR SEPARATORS) 


OPERATION ~~ , VARIABLE COMMENT* 


FORMAT FOR NO LABEL OR VARIABLE FIELD. 
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a character string. Each statement is terminated by a carriage return (CR) followed by a line 
feed (LF). 


The four fields used when free format input to the DAS assembier is selected are: 


a. Label field use is governed by the requirements of the instruction or directive. It is 
terminated with a comma or blank. If this field is not used, a comma appears as the first 
character of the source statement. 


b. The operation field contains the instruction or directive mnemonic. An asterisk 
following the mnemonic specifies indirect addressing. This field begins immediately 
following the label field terminator and is terminated by a comma or blank. 


c. | The variable field can be blank, or contain one or more subfields separated by comrnas or 
blanks. It must immediately follow the instruction field terminator (comma or blank). 
Subfields can be voided by using adjacent comrnas or blanks. This field is terrninated by 
a blank that is not part of a character string, or with a CR or LF. 


d. The comment field fills the remainder of the staternent (frorn the terminating blank of 
the variable field to the next CR or LF). 


If the first nonblank character of a source statement is an asterisk, the entire statement is a 
comment. 


The free format where commas are used as separators is shown in figure 5-1. Note that any 
source input may use either free or fixed format. 


5.1.2 Pass 1 - Symbol Table 

During pass 1, the DAS assembler reads the source program and constructs a symbol table of 
all symbols appearing in the source program. For each symbol in the table, there is a 
corresponding value, usually an address in memory. Symbol table capacities are summarized 
in table 5-1. 


Table 5-1. DAS Symbol Table Capacities 


Assembler 8K Memory Greater than 8K Memory 


440 + n (800) 


20 + n (800) 


where n = number of 4K memory increments 
above 8K. 
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5.1.3 Pass 2 - Assembler Output 


DAS produces a source/object listing of the assembled program, as well as an object program 
in reloadable format. The object program may be output to any BO device supported by the 
operating system. 


The listing can be obtained in whole or in part as the program is being assembled. The source 
(symbolic) program and the object (absolute) program are listed side by side on the listing 
device. This device can be any LO device supported by the operating system. 


The listing is output according to the specifications given by the list and punch control 
directives in the assembly (DAS 8A, DAS MR). 


Error analysis during assembly causes error messages (section 5.1.4) to be output on the line 
following the point of detection. 


Figure 5-2 illustrates the format of the output listing. The columns are further described 
below: 


Address This column shows the current location 
counter value in octal. It is incre- 
mented for each word of object code. 


Code Most entries in this column are words 
of object code (in octal). The values 
of symbols assigned via symbol definition 
directives (EQU, SET, etc.) are also 
shown in this column but are not part 
of the object code. 


Mode An indication of the addressing mode, 
as follows: 

A Absolute value 

C Common 

E Externally defined 

| Indirect Pointer 

L Literal Pointer 

R Relative address value 
Line Count The assembler assigns a unique ascending 
(DAS MR only) integer number to each non-blank input 


statement in order of sequence in the 
input source deck, starting with 1. This 
statement number is listed in the fourth 
column, and is used to cross reference 
error messages to the statements which 
caused the errors. Statements generated 
by macro expansions are not assigned 

a statement number. All statements 
generated by a DUP directive have the 
same line number. 
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Symbolic Source Reproduces the source statements as 


Statement 


input, with additional lines showing 
directive-duplicated statements and 
macro expansion space. 


Line Symbolic 

Address Code Mode Count Source Statement 
014000 1 ORG 014000 
014000 000000 2 ABS ENTR 
014001 001002 3 JAP* ABS 
014002 114000 s 
014003 005211 4 CPA 
014004 001000 5 JMP* ABS 
014005 114000 i 

000000 6 END 


Figure 5-2. Output Listing Format 


5.1.4 Error Messages 


The assembler checks source statement syntax during both pass 1 and 2. Detectable errors 
are listed during pass 2. 


The error message appears in the listing line following the statement found to be in error. 
Each line can hold up to four error messages. 


The DAS error codes and their meanings are listed in table 5-2. 


Table 5-2. DAS Error Codes 


Meaning 


Error in an address expression 


Decimal character in an octal constant 


legal redefinition of a symbol or the 
location counter 


Incorrectly formed statement 


Illegally constructed expression 


Floating-point number contains a format 
error 


First nonblank character of a source 
statement is invalid (the statement 
is not processed) 
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Table 5-2. DAS Error Codes (continued) 


Meaning 


ee 


Inconsistent use of indexing and 
indirect addressing 


Missing right quotation mark in 
character string 


No memory space available for additional 
entries in assembler tables 


No symbol in the label field of a SET, 
EQU, MAC, or FORM directive or no 
symbol in the label or variable field of 
an OPSY directive, or no symbol in the 
variable field of a NAME directive. 


Undefined operation field (two No 
Operation (NOP) instructions are 
generated in the object program; the 
remainder of the statement is not 
processed), or illegal nesting of 

DUP or MAC directives or DUP of a 
macro call 


Illegal use of prime (’) 


Relocatable item where an absolute 
item should be defined 


Synchronization error: symbol value 

in pass 2 is different frorn that 

found in pass 1 

Undefined symbol in an expression 
Expression value too large for a 
subfield, or a DUP directive specifies 
that more than three statements are to 
be assembled (m parameter) 


Undefined or illegal indexing specification 


Undefined character in an arithmetic 
expression 


Undefined symbol in the variable 
field of a USE directive 
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Table 5-2. DAS Error Codes (continued) 


Code Meaning 


*VF Instruction contains variable subfields 
either missing or inconsistent with 
the instruction type 


*XR Address out of range for an indexing 
specification 


® Invalid use of literal 


|| Implicit indirect reference when | 
parameter is present on the /DASMR 
directive. 


SE Missing “END” card error (DAS MR with 
VORTEX | and VORTEX Il) 


SM Missing “MEND" carderror (DAS MR with 
VORTEX | and VORTEX Il) 


$G Missing "GOTO" target error (DAS MR 
with VORTEX | and VORTEX II) 


Note: The resulting output listing may not 
reflect the source code syntax correctly. 
There rnay be erroneous missing syrnbol 
errors, etc., Since only a partial assernbly 
is perforrned on detection of a rnissing 
target error. The listing is meant to be 
used as an aid to locating the rnissing 
target. 


$| 1/O Error (DAS MR with VORTEX | and 
VORTEX Il) 


ss Syrnbol overflow error (DAS MR with 
VORTEX | and VORTEX Il) 
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5.2 ASSEMBLER OPERATING PROCEDURES 


Since DAS MR operates under MOS or VORTEX and uses the MOS or VORTEX 1/0 control 
system, the I/O devices can be defined as required. 


DAS MR uses the secondary storage device unit for pass 1 output. It inputs the symbolic 
source statements from the processor input (Pl) logical unit in alphanumeric mode, and 
outputs them in the same mode on the processor output (PO) logical unit. When DAS MR 
detects the END directive, it terminates pass 1, returns to the beginning of the source 
program, and begins pass 2. During pass 2, the source statements are the input from the 
system scratch (SS) logical! unit, a listing is output on the LO unit, and the binary object 
program is output on the BO unit. 


Sections 5.2.1, 5.2.2, and 5.2.3 describe DAS MR operations in different environments. DAS 
8A operation is described in section 5.2.4. 


5.2.1 DAS MR Operation (VORTEX I/VORTEX II) 


The /DASMR directive schedules the DAS MR assembler with the specified options for 
background operation on priority level 1. It has the general form: 


/DASMR, p(1),p(2)...,P(n) 
where: 


each p(n) if any, is a single character 
specifying one of the options 
shown in table 5-3. The /DASMR 
directive can contain up to six 
such parameters in any order. 


Table 5-3. DAS MR Options for Background Operation 


Absence 


Parameter Presence 


Suppresses binary object Output binary object 


Outputs binary object on GO 
file 


Suppresses output of binary 
object on GO file 


nnn oe ee re reel 


Suppresses symbol-table listing Output symbol-table listing 


Suppresses source listing Outputs source listing 


Flags implicit indirect 
instructions with '*Il error’. 


Assembles implicit indirect 
instructions. 


(DAS MR with VORTEX | and VORTEX II) 
Addressing and generated code lists are 
printed in hexadecimal. 


(DAS MR with VORTEX | and VORTEX II) 
Addressing and generated code lists are 
printed in octal. 
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The DAS MR assembler reads source records from the VORTEX PI logical unit on the first 
pass. The PI unit must be set to the beginning of the source file before the /DASMR directive 
is executed. This can be done with an /ASSIGN, /SFILE, /REW, or /PFILE directives. A load- 
and-go operation requires, in addition, an /EXEC directive. Details of the preceding 
directives are given in the V70 VORTEX! or VORTEX II Operating System Reference Manual. 


Shown below is an example for scheduling the DAS MR with no source listing but with the 
binary object output on the VORTEX logical unit GO file: 


/ JOB, EXAMPLE 
/DASMR,N,L,B 


/JOB (as well as /ENDJOB or /FINI) initializes the GO file to start of file. If BO is assigned to 
a rotating memory partition, a/PFILE,BO,,BO must precede the /DASMR directive to initial- 
ize the file (unless the assembly is part of a stacked job). 


DAS MR uses the secondary storage device unit for pass 1 output. It reads a source module 
from the PI logical unit and outputs it on the PO unit. The source input for pass 2 is entered 
from the SS logical unit. 


When an END statement is encountered, the SS unit is repositioned and reread. During pass 
2, the output can be directed to the BO and/or GO units for the object module and the LO 
unit for the assembly listing. The SS or PO file, which contains a copy of the source module, 
can be used as input to a subsequent assembly. 


DAS MR has a symbol-table area for 175 symbols at five words per symbol. To increase this 
area, input before the /DASMR directive a /MEM directive where each 512-word block 
enlarges the capacity of the table by 100 symbols. 


A VORTEX II physical record on an RMD is 120 words. Source records on RMD are blocked 
three 40-word records per VORTEX II physical record, and object modules on RMD are 
blocked two 60-word modules per record. However, in the case where SI = PI = RMD, 
records are not blocked but assumed to be one per VORTEX I! physical record. When an input 
file contains more than one source module each new source module must start at a physical 
record boundary. Unused portions of the last physical record of the previous source modules 
should be padded with blank records. Proper blocking may be ensured by following the END 
statement of the previous Source module with two blank records. 


Figure 5-3 shows the listing output resulting from assembling and executing a sample DAS 
MR program under VORTEX Il. 


13#26%43 /J08,S5WI1TCH 
13326:49 /KPMODE,0O 
13396:92 /DASMA.L,8 


Figure 5-3. Example of Assembled and Executed DAS MR Program 
Under VORTEX Conirol 
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000000 
000001 
000002 
000003 
090004 


000008 
000006 
000007 
000010 
000011 


000012 
000013 
0000144 
000015 
0000176 
000047 
0000206 


1 O8a{6276 


000000 


600001 
000002 
000024 
000050 
000004 
609005 
aoaaoog 
00000! 
000001 
9006000 


006505 
000000 
001404 
000075 
000050 


906505 
o0n001 
001405 
000074 
0000514 


006505 
100000 
100000 
610004 
000000 
600000 
000000 
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SwITChH 
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READ 


VORTEX DASMR {326 HOURS 
NAME SkITCH 
EQU * 
EXT PIFCB,LNFCR 
EQU { 
EQU 2 
EQU 20 SWITCH COUNT 
EAU COUNT# COUNT RECORD LENGTH (CIN WORDS) 
EQU 4 PROCESSOR INPUT 
EQU 5 LISTING QUTPUT 
EQU Q WATT FOR 10 
EQY { IMMEDTATE RETURN 
EOU { 
EQU * 
IOLINK PY,BUFF,RECL 
IQLINK LO,CNTRL,RECL #14 
READ PIFCB,PE,WATT,ASCII 


17 READCR STAT 


READ,END, END, END,READCR 
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19 DOIT 
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28 
29 
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5.2.2 DAS MR Operation (MOS) 


The DAS MR assembler may be loaded and executed under the Master Operating Syston 
(MOS) using the following directives: 


/ ASSEMBLE 
/A,P(1),P(2),---P(A) 


This contre! directive directs the executive to load the assembler. The parameter string 
specifies optional tasks for the assembler or executive to perform after the assembly is 


completed. These tasks are: 


Parameter Definition Default Assignment 

N No source listing Source listing 

Bo No binary object Binary object program output 
MAP Memory map on load-and-go No memory map on load-and-go 
L Load-and-go after assembly No load-and-go after assembly 
M No symbol table listing Symbol table listing 


To read the same physical symbolic source statements for both assembly passes, input: 


/ASSIGN PO=DUM,SI=PI 
/ASSEMBLE 


The processor output listing serves as a copy of the program; it can be input for another 
assembly. 


During a DAS MR assembly operation, if logical unit SS is not a magnetic tape unit, a flag bit 
is set in the peripheral control word PCW. When the end of pass 1 is detected, this bit is 
interrogated. If it is set, DAS MR does a status check on logical unit PO, prints the message 
RELOAD SOURCE on the Teletype, and halts. When the computer is placed in the run mode, 
DAS MR rewinds logical unit SS and begins pass 2 of the assembly. If the flag bit is not set 
(SS not equal to magnetic tape), no status check is done on PO and DAS MR immediately 
rewinds logical unit SS and begins pass 2. 


Figure 5-4 illustrates a sample program assembly under MOS. 


/JOB, EXAMPLE 
/OATE, 08017076 
/ASSEMBLE, Bal 


Figure 5-4. Example of Assembled and Executed DAS MR Program 
Under MOS Control 
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10 NATA 


STRT 
0106642 


0 
§,356,NAME 


5,24, nS, 42,496 


EXYT 


CRLF,'ODEAN J, 


CRLF,I975 N, 


CRLF, ORANGE 


CRLF, 'CALIF 


GRAND! 


QRANGE! 


926671,CeLF,# 


Figure 5-4. Example of Assembled and Executed DAS MR Program 
Under MOS Control (continued) 


GASTON! 


PAGE 


000050 
000051 
900052 
900053 
000054 
000055 
000086 
900057 
000060 
9000684 
000064 


2 EXAMPLE 


4417014 
4463114 
443240 
12924n 
120246 
434669 
433266 
433640 
106612 
oRekebel els) 


000000 


PP PPT rppP bp b> b> > 


OPERATING THE ASSEMBLER 


08917976 


44 Last BES 0 
42 Ext? EXT 


3 FN STRT 


ENTRY NAMES 
ONDN0O R STRT 
EXTERNAL NAMES 
o00015 E EXIT 
SYMBOLS 
(106612 A CRLF 000018 E EXIT 
000016 R NAME 000000 R STRY 
© ERRORS ASSEMBLY COMPLETE 


OOEAN J, GASTNN 
975 N, GRAND 

ORANGE ORANGE 
CALIF 92667 


n00006 E I1acs 
00nN006 E INCS 


NO0N064 R LAST 


Figure 5-4. Example of Assembled and Executed DAS MR Program 


Under MOS Control (continued) 
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5.2.3 DAS MR Operation (Stand-Alone) 


DAS MR may be loaded and executed under control of the stand-alone FORTRAN IV loader. 
The operating procedure is as follows: 


a. 
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Load the stand-alone loader using the binary load/dump program (BLD II). Set A register to 
zero before loading to prevent execution of the stand-alone loader. At completion of 
loading, the execution address of the stand-alone loader will be in the X register 
(013260). 


Make the following modifications to memory; 


Location New Contents 
5 0210 
6 0210 
7 0210 


Execute the stand-alone loader by setting the P register to the execution address 
determined in step a and pressing RUN. 


When executed, the stand-alone laoder will print '’'LN’’ on the Teletype. At this time, 
peripheral device assignments may be altered by entering the one-digit number of the 
old logical unit followed by the two-digit number of the substitute unit. DAS MR uses the 
following logical units: 


Logical Logical Default 


Unit Unit Device 

Number Name Assignment 

3 P| Card reader 

4 LO Line printer 

2 BO Paper tape punch 
6 GO Dummy 

8 SS Magnetic tape* 00 
9 PO Magnetic tape** 10 


* Device Address 010 
** Device Address 011 


As an example of device reassignment: 


LN 
300400201806900 


Would reassign: 


Pi = Teletype Keyboard 

LO = Teletype Printer 

BO = Teletype Paper Tape Punch 
SS = Teletype Keyboard 

PO = Dummy 


For acomplete list of peripheral assignments, see table 5-4. 
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Table 5-4, List of Peripheral Assignments for Stand-Alone DAS MR 


Logical Assignment 
Unit 
Number 
0 Teletype keyboard and printer 
1 Teletype paper tape reader and punch 
2 High-speed paper tape reader/punch 
3 Card reader 
4 Line printer 
5 Dummy 
6 Dummy 
7 Card punch 
8 Magnetic tape unit 0 
9 Magnetic tape unit 1 
10 Magnetic tape unit 2 
1] Magnetic tape unit 3 
12 Unformatted paper tape !/O (HSPT) 


e. Following device reassignments, the stand-alone loader will print "IN”’ on the Teletype. At 
this time, the operator should ready the DAS MR object on the input device and respond 


by typing the proper designation on the Teletype: 
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Paper Tape Reader 

Teletype Paper Tape Reader 

1, 2, 3 = Magnetic Tape Controller 
0, 1, 2, or 3 respectively 


oA 
Il 


To enable print out of a load map, the operator must type '’M”’ immediately following the 
device designator. Following the typed characters, the operator must type a CR (carriage 
return) to initiate loading of the DAS MR object. 


lf an error is detected, the loader types a 2-character error message code and halts. To 
continue, the operator should remove ,the cause of the error (refer to error messages), 
ready the input device to read from the beginning of the object material, reload the 
loader program, and repeat the above procedure. 


Error Messages 


The following 2-character error messages are output to the Teletype whenever the cor- 
responding error condition is detected: 


Messages Meaning 


PS Program Size Error. Program memory requirements exceed 
available program/common storage. 


LS Literal Size Error. Program literal requirements exceed 
available literal storage. 


CM Common Error. The program contains conflicting size 
definitions for a common block. 


DA Data Error. The program attempted to overlay the loader, 
loader tables, or resident programs. 


TX Text Error. The program object text contains an illegal or 
erroneous loader code. 


RD Read Error. The loader encountered a read error while 
attempting input of object text. 


RC Record Error. The loader inputs an invalid record type. 


SQ Sequence Error. The loader inputs an object text record 
with an invalid sequence number. 


CK Check-Sum Error. The loader inputs an object text record 
with an invalid check-sum. 


f. After DAS'MR is loaded, peripheral devices for logical units 3, 4, 2, 6, 8, and 9 must be 
loaded from the Run-Time !/O tape. This is accomplished by placing the Run-Time I/O 
tape on the input device and repeating step e. 
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g. After the Run-Time |/O is loaded, the 1/0 control program must be loaded from the Run- 
Time utility tape. This is accomplished by placing the Run-Time utility tape on the input 
device and repeating step e. 


h. When all externals have been satisfied the loader will halt with the P register = 3. To 
execute DAS MR, the operator should press RUN. 


Upon execution, DAS MR will input source statements from logical unit (Pl), output source for 
pass to logical unit (PO), input pass source from logical unit (SS), output binary object to 
logical unit (BO), and output listing to logical unit (LO). 


Source input to DAS MR terminates upon input of either an EOF or a source record containing 
a slash (/) as the first character. A slash record will cause an end-of-file to be output to the 
BO device. 


5.2.4 DAS 8A Operation 


The DAS 8A assembler may be loaded and executed by the stand-alone procedure described 
in the following paragraphs. 


Loading the Assembler. Load the assembler program into memory using the binary load/dump 
program (BLD II). Execute it by entering a positive, nonzero value in the A register during 
loading, or by clearing all registers, pressing (SYSTEM) RESET and entering the RUN state. 
(Set RUN indicator on and press START). 


During execution, the program first determines the amount of memory required. It. then 
stores in address 000003 a value one less than the lower limit of BLD II. This is the highest 
address that the assembler can use without destroying part of BLD II. 


DAS 8A comprises two sections: The I/O section allows the specification of |/O devices for 
assembler input and output. The second section is the assembler itself. 


1/O Section Operation. The |/O section of DAS 8A, using the Teletype printer, makes three 
requests for definitions of 1/O devices: 


ENTER DEVICE NAME FOR xx 


where xx is one of the |/O function names: SI (source input), LO (list output), or BO (binary 
output), respectively. 


1/0 Device Assignment. Assignment of I/O devices is accomplished by responding to each 
request in turn by means of a Teletype keyboard input which names the desired device, 
followed by a carriage return (CR). The acceptable device names for each request are listed in 
table 5-5. If the default assignment is desired, press CR only. 

if an incorrect device name is type, the message: 


DEVICE NAME NOT VALID 


is Output and the request repeated. 
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To terminate the output of any line to the Teletype, press RUBOUT. The error correction 
feature can be used any time during I/O device specification. 


When |/O assignments are complete, the I/O section uses BLD II to load the assembler 
section into memory. 


To restart the I/O section before the assembler section is loaded, set STEP indicator on, clear 
all registers, press (SYSTEM) RESET, set RUN indicator on and press START. 


Table 5-5. Acceptable 1/0 Devices 


Assembly Device Description Default 
Function Assignment 
SI (source input) TR Teletype paper tape read 
TY Teletype keyboard 
PR High-speed paper tape 
reader 
CR Card reader (026 code) 
CR1 Card reader (029 code) 
MTnn Magnetic tape 
LO (list output) TY Teletype printer 
: LP2 Line printer (70-6701) 
BO (binary output) TP Teletype paper tape punch 
PP High-speed paper tape 
punch 
CP Card punch 


MTnn Magnetic tape 


Assembler Section Operation. When BLD II relinquishes control to the assembler section, the 
computer halts with 000001 in the program counter (P register). For an assembler pass 1, set 
SENSE switch 1; for pass 2, reset SENSE switch 1 and set SENSE switches 2 and 3. 


If pass 1 is selected, ready the SI device with the source input media and set RUN indicator 
on and press START. 


For pass 2, ready the SI device with the source input media, ready the BO and LO devices, set 
RUN indicator on and press START. 


The END directive terminates both passes 1 and 2. Pass 1 terminates with 000001 in the P 
register and 0177777 in the A register. Pass 2 produces the binary object loader text and 
program listing and terminates when END ts encountered with the same register values as 
pass 1. A MORE directive causes the computer to stop and wait until the SI unit prepared with 
the additional source input media, and the RUN state is entered. MORE is indicated by 
0170017 in the A register. 


Od 
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The program listing can be suppressed during pass 2 by resetting SENSE switch 2, and the 
binary output, resetting SENSE switch 3. Error messages cannot be suppressed and are 
output on the LO device as the error is detected during pass 2. 


Synchronization errors halt the assembly with 000777 in the A register. To continue the 
assembly, set RUN indicator and press START. The assembler resets the location counter 
value to that assigned on pass 1, prints error message *SE, and continues the assembly. 


Pass 2 can be restarted or repeated for extra copies of the assembled program without 
repeating pass 1. 


At the completion of pass 2, the assembler can accept another assembly using the same |/O 
devices. For other |1/O devices, reload the assembler program, starting with the I/O section. 


To restart the assembler, set STEP indicator on, clear all registers, press (SYSTEM) RESET, 
set RUN indicator on and press START. The assembler halts with 000001 in the P register 
and is ready to accept another assembly. 


Using Magnetic Tape. The DAS 8A assembler can communicate with any of the magnetic tape 
transports on a controller. Up to four transports may be connected to each of the tape 
controllers. A configuration may have one to four magnetic tape controllers. 


The magnetic tape transport number and controller device address is specified in the device 


name specification of the |/O Control Section. A listing. of magnetic tape transport device 
names with their corresponding tape transport number and address is given in table 5-6. 


Table 5-6. Device Names for Magnetic Tape Transports 


Device Transport 
Name Number 


MT0O 010 


S23 


veG 


ZIEO- CIN 


ajdwexy Gulpog ‘s-s ainbig 


DAS CODING FORM 


Tsquare R OT PROGRAM 


Veet wade 


ETURIN FOR SOVARE 4 F NEGATIVE NUMBERS IS _IN CALL 
sarees NIORMAL RETURN FROM SQUARE ROST IS AT CALL + 3 (n+3). 
¥ THis ROUT INE IS DESIGNED TG TAKE THE SQUARE ROOT 

OF GO @CTAL! NUMBERS AND ST@RE THE ANSWER IN 40 OCTAL LGC. 


i 

iS TART NG ADDRESS 
KR = C@OuNT - | 
ye (Lge + XR) 


SUBR CALL WITH ERR@R RETURN 
RETURN ST@RE RESULT 


Tee -40,50,60,70,80,90,110,120 
0.,02000,2,9, oes 03000,15,17,1/30,0140 | 
04,300 31. 5 o , 550 134.0, 350, 400, 500, =O, 


‘y-G a1NBiy Ul UMOUS SI S401 


yim weiboud yg SVq Ppalquesse ue jo ajdwexe uy ‘g-g asnby ul UMOYS S| weiboid Vg svad 


pa|quuasse ue jo ejdwexe uy ‘s-s a4nBy ul umoys si wesbosd V8 SVC B JO aj]dwexa Buipoo v 


4S 1GINASSV JHL ONILVWHAadO 


Gos 


(penunuos) ajdwexy Buripog “g-¢ anby4 


E9EO-ZIN 


SQRT 


BAS CODING FORM 


“BSS [ . RESERVE 40 $CTAL LOCATIONS 


WITH INUMBER FOR SQvARE ROOT 


NUMBER / 
A/K = BR 


BY THE APPROXIMATION 


IN THE B REGISTER.~ THE 
ERRGR RETURN FOR 


APPROX IMATIGN 
= AR 


YA TEWASSV SHL ONILVYadO 


92°G 


(panunuod) asjdwexy Buipoy ‘s-s aunbig 


v9EO-ZIN 


DAS CODING FORM 


A/X+X =AR 
A/X+X =AR °BR 
CA/Xt*X) 1/2 =BR 


COMPLETE APPROXIMATION 
RESTPYRE XR 
UPDATE ENTRY To n+3 


Yd TEWASSV JHL ONILVYHAdO 


PAGE 200001 

000500 

000500 006030 
O00KOs 000037 
000502 025815 
000503 02006 
000504 000624 
009595 000777 
O0OSOR 0655566 
000507 001040 
900510 oocst14 
OOO511 Of5344 
000512 on1000 
000813 0n0502 
600814 on6000 
000515 00031 
600516 000036 
000517 Onoda 
000520 070050 
000821 477777 
900522 00144 
000523 onn0n01 
000524 900000 
900525 000000 
OH0526 nnnooa 
000527 009310 
00530 001750 
00531 000700 
OOOK32 177730 
000533 000062 
O00K34 an0074 

PPOLGi7y 
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aEX AMPLE SQUARE RNOT PROGRAM 
® 
« THIS A ROUTINE Tr CALL THE SQUARE FONT (XSAT) SURROUTINE, 
» ERROR RETURN FOR SQUARE ROOT OF NEGATIVE NUMBERS TS IN CALL 
* #2 (N#2) NORMAL RETURN FROM SQUARE ROOT IS AT CALL + 3 (Ned) 
» THIS ROUTINE IS DESIGNEN TO TAKE THE SQUARE ROOT 
w  «=0F 40 OCTAL NUMRERS ANO STORE THE ANSWER IN 40 CCTAL LOC, 
* 
,ORG 20500 STARTING ANDRESS 
7LOXT 7037 XR @& COUNT e& } 
NEXT ,LDB Fe 4 oer | BR se (1L0C # XR} 
CALL »XSOT,0777 SUBR CALL WITH ERROR RETURN 
,STB ,SQRT, 1 NORMAL RETURN STORE RESULT 
] 
* NOTE THAT THE DATA IS RETRIEVED AND STORED FROM 
« BOTTOM TO TOP 
* 
1JXZ »HALT ¥R © 0 END OF ROUTINE 
,DXR F INDEX » { = INDEX 
,JMP »NEYT RETURN FOR NEXT NUMBER 
HALT ,RLT NORMAL HALT 


Loc =, DATA 


,DATA 


‘ 
725,30,36,050,-1,190,01,600,0,4,200 


,1000,0700,"40,50,60,70,80,90,110, 120 


Figure 5-6. Example of an Assembled DAS 8A Program 
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PAGE 


000535 
000536 
000537 
000540 
0000S 44 
00054? 
000543 
'000544 
000545 
000546 
000547 
000550 
0n0551 
000552 
000553 
000554 
000555 
. 000556 
000557 
000560 
000561 
000562 
000563 
000564 
000565 
000566 


000626 
000627 
000630 
0nn631 
000632 


BTU-1172 
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000002 


090106 
000120 
000132 
000156 
000170 
000000 
002000 
000002 
000011 
005670 
003000 
000017 
000021 
000202 
ongoo! 
000204 
000454 
000446 
000500 
000512 
000524 
000536 
000620 
000764 
177766 


000000 
001920 
900657 
005421 
901004 


»DATA 60, 02000,2,9,3000,03000,15,17,130,01 40 
pg DATA 2 9204,3800,310,370,5380,540,350,400,500, 910 


ORT ,8S8 7940 RESERVE 40 OCTAL LOCATIONS 
INTEGER SQUARE ROOT SUBROUTINE CALCULATED BY THE APPROXIMATION 


y+ 


$ 

* 

a 

i A 

® 1/2 (X +—) =X 

e x4 

« ENTER WITH NUMBER FOR SQUARE ROOT IN THE 8 REGISTER, THE 

« ¥ REGISTER IS SAVED AND REPLACED ON EXIT, ERROR RETURN FOR 
« SQUARE ROOT OF NEGATIVE NUMBERS AT N*2 FROM CALL, 

* NORMAL RETURN AT NOS FROM CALL WITH SQUARE ROOT OF NUMBER 
ft 
* 
x 


IN THE 8 REGISTER 


SaY ,€NTR ’ PLACE WHERE RETURN ADDR IS SAVED 
7 JBZ eUXITes SQ RT, OF 080 
7TBA ’ NUMBER » BR ®@ AR 
7JANe eXSOT FRROR RETURN TO Ne? 


Figure 5-6. Example of an Assembled DAS 8A Program (continued) 


PAGE j00003 
ON0K6S3 109626 
000634 60862 
000635 Gahd66Ss 
ONOK3B 070664 
090837 NOBN3N 
00640 000097 
000641 05001 
000642 0204662 
0900645 170663 
009644 905021 
0906845 120663 
000646 005912 
ON06847 On4i0o1 
900650 0660663 
0006541 905344 
900652 001040 
000653 000856 
000634 601000 
000655 000641 
0006356 030664 
ON0887 040626 
00nk60 001000 
0006461 100626 
900662 
000663 
090664 

000090 

LITERALS 

PNINTERS 

SYMAQLS 

1 000664 RR SAVE 

1 000663 R- APRX 

1 QON662 R NMAR 

1 000656 RR EXIY 

1 000841 R- AGN 

4 000626 R XS8AT 

1 00866 R- SQrRrT 
VITUL-1173 


PAGE 000004 


$ 060515 R Lac 
4 00514 R HALT 
4 900502 R NEXT 


VITEL-LI74 


R 


R 


AGN 


EXIT 


NMBR 
APRX 
SAVE 


aNMRR 
, APRX 
7 SAVE 
? 


' 
»NMBR 
, APRX 
¢ 


, 
ai 
,APRYX 


, 
2EXIT 


,»AGN 


p SAVE 
»XSOT 
»XSOT 
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SAVE NUMBER 

NUMBER = 1ST APPROXIMATION 
SAVE XR 

INITYALIZE XR FOR APPR, 


7TERQ AR FOR NMIVIDE 
NUMBER « BR 

NUMBER / APPROXIMATICN 
A/X =wBR ZAR 

A/X#X BAR 

A/X*¥ BAR BBR 
(A/X4#X91/2 =BR 

NEXT APPROXIMATION 

XRe { &XR 

SA RT, AR 


COMPLETE APPROXIMATION 
RESTORE XR 


UPDATE ENTRY TO Nee 
GO BACK TO MAIN PROGRAM 


NQ EXECUTICQN ANDRESS 


Figure 5-6. Example of an Assembled DAS 8A Program (continued) 
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PAGE 100001 
015000 
0158000 oOn8e{!s 
"§Z 
015001 oo5o004 
*D0 
015002 001411 
wS7Z 
015003 000777 
015004 015038 
# AD 
015005 906015 
015006 015036 
0145007 006030 
OL50C10 = O15034 
915911 a1509n 
*D0 
015012 0600004 
“TF 
015013 015900 
015014 016000 
o1689t8 014020 
O15016 on6010 
*8Z 
015017 027721 
015020, 006010 
915021 077777 
015922 on601i0 
015923 077777 
015024 006010 
015925 100900 
«fp 
0415030 nn1in4da 
0145031 015036 
095032 on1000 
wSY 
015033 900000 
015934 9001000 
OLS5S03£ 915037 
018036 090905 
015037 014048 
VTU-1L77 
PAGE 000002 
045040 
0970000 
LITERALS 
POINTERS 
SYMANLS 
6 015040 R STP 
1 oOy8O37 R ARAV 
1 0185036 R ALFA 
o oy8oo0i RR SEC 
e7Ul- 1178 
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SEC 


SEC 


STR 


ORG 


TTA, 


TZA 


»HLT 
,LDA 


»LDAE 
sLOXI 
yLDA 
»LDA 
»LDA 
»LDA 
7L DA 
»LOAT 
»LDAT 
»LDAI 
»LDAY 
1422 
, 3X2 


, JMP 


7JMP 


,DATA 
,DATA 


,BSS 
,END 


2918000 
»910 


‘ 
,777 


90777 
ALFA, 


aALFA,4 


e ALFA 


EXAMPLE WITH ERRORS 
CANNOT HAVE A VAR, FIELD: 


VARTABLE FIELD TO LARGE 


EXP { TO LARGE 


MOUBLE DEFINITION 


EXP 2 HAS TO BE Ad OR 2 


CREATE A REL ADDRESS 
VAR FIELD TO LARGE 


ILLEGAL OPERATION CONE 


BRA UNDEFINED 


Figure 5-7. Example of an Assembled DAS 8A Program with Errors 


SECTION 6 
STAND-ALONE FORTRAN/DAS MR LIBRARIES 


There are eight libraries for the stand-alone FORTRAN/DAS MR system. 


6.1 COMPLEX MATH FUNCTIONS (FORTRAN CODED) 


This library consists of programs, collected, without modification, from the MOS. In order, they 
are: . . 


$9E $AC 
CCOS CMPLX 
CSIN $8K 
CLOG $8L 
CEXP $8M 
CSQRT $8N 
CABS $ZD 
CONJG AIMAG 
$AK $0C 
SAL REAL 
$AM $8F 
SAN $8S 


6.2 DOUBLE PRECISION MATH FUNCTIONS (FORTRAN CODED) 


This library consists of programs collected, without modification, from the MOS. in order, they 
are: 


$XE DMINI 
$YE DSIGN 
$ZE $YK 
DATAN2 $YL 
DLOGIO $YM 
DMOD $YN 
DINT DBLE 
DABS $XC 
DMAXI 


6.3 SINGLE PRECISION MATH FUNCTIONS (FORTRAN CODED) 


This library consists of programs collected, without modification, from the MOS. In order, they 
are: 


TANH SNGL 
ATAN2 MAX0O 
ALOGI0 MAX] 
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AMOD MINO 
AINT MIN1 
AMAXO MOD 
AMAX1 INT 
AMINO IDIM 
AMIN IFIX 
DIM $JC 
FLOAT 


6.4 DOUBLE PRECISION ARITHMETIC (DAS CODED) 


This library consists of programs collected from the MOS. The only modifications made were 
the deleting or adding of control cards to define the object code for 16- or 18-bit machines. In 


order, they are: 


DSINCOS DMULT 
DATAN DDIVIDE 
DEXP DADDSUB 
DLOG DNORMAL 
IF DLOADAC 
POLY DSTOREAC 
CHEB RLOADAC 
DSQRT SINGLE 
$DFR DOUBLE 
IDINT DBLECOMP 


6.5 SINGLE PRECISION ARITHMETIC (DAS CODED) 


6.5.1 Hardware Multiply/Divide 


This library consists of programs collected from the MOS. The only modifications made were 
the deleting or adding of control cards to define the object code for 16- or 18-bit machines. !n 


order, they are: 


$HE XDADD 
$PE XDSUB 
$QE XECOMP 
ALOG $FLOAT 
EXP $IFIX 
ATAN IABS 
SORT-H ABS 
SINCOS ISIGN 
FMULDIV SIGN 


FADDSUB  =— $HN-H 
SEPMANTI — $HM-H 
FNORMAL = XMUL 
XDDIV-H XDIV 
XDMULT-H _I$FA 
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6.5.2 SOFTWARE MULTIPLY/DIVIDE 


This library consists of programs collected from the MOS. The only modifications made were 
the deleting or adding of control cards to define the object code for 16- or 18-bit machines. In 
order, they are: 


$HE XDADD 
$PE XDSUB 
$QE XDCOMP 
ALOG $FLOAT 
EXP SIFIX 
ATAN IABS 
SORT-S ABS 
SINCO ISIGN 
FMULDIV SIGN 
FADDSUB $HN-S 
SEPMANTI $HM-S 
FNORMAL $XMUL 
XDDIV-S XDIV 
XDMULT-S ISFA 


6.6 RUN-TIME |1/O (DAS CODED) 


This library consists of programs collected from the MOS. Control cards were added or deleted 
to define the object code for 16- or 18-bit machines. 


Two additional modifications were made to the MOS routines: the Teletype paper tape reader 
and punch drivers were merged into a single driver, $OH/$01; and the entry name of the 
driver for the line printer was changed to $OR. In order, they are: 


FORTIO MT$3 
$00 MTAE 
$04 KNT$ 
$08 RDC$ 
$0C WRT$ 
$0G STR$ 
$0H/$01 SWR$ 
$00 BL$P 
$0M FCH$ 
CRIE TCK$ 
$OQ(FOR) $TCOl 
$0Q $HC37 
$0P HCK$ 
$0S DIM$ 
CPAE LAS$ 
MT$0 lOA$ 
MT$1 100K 
MT$2 $BICD 
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6.7 RUN-TIME UTILITIES (DAS CODED) 


This library, except for $BUF consists of MOS programs, some modified and some not. In the 
following list, an asterisk (*) flags the programs which have more extensive modifications 
than selecting the 16- or 18-bit word size. In order, they are: 


$DO $EE 

$CG RSCB3* 
$38 RSCBIMTB* 
$SE $BUF 
FORTUTIL 
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Ninemonic 


AD 


APPENDIX A 


INDEX OF INSTRUCTIONS 


Octal 
Code 


0072xx 
1L2Xxxx 
00612x 
00745x 
006120 
0075xx 
15xxxx 
00615x 
006150 
005511 
005522 
005544 
004200 +n 
004000 +n 
004300 + n 
004100 +n 


007404 


0064xx 
1025xx 
1027xx 
1026xx 


00743x 


Description 


Add 

Add memory to A register 

Add extended 

Add immediate 

Add immediate 

Add register 

AND memory and A register 
AND extended 

AND immediate 

Add overflow to A register 

Add overflow to B register 

Add overflow to X register 
Arithmetic shift left A register 
Arithmetic shift left B register 
Arithmetic shift right A register 
Arithmetic shift right B register 


Block Move (V77-800 extended 
instructions only) 


Bit test 

Clear and input to A register 

Clear and input to A and B registers 
Clear and input to B register 


Complement register 


A-1 


INDEX OF INSTRUCTIONS 


A-2 


Mnemonic 


COMP 


CPA 


CPB 


CPX 


DADD 


DAN 


DAR 


DBR 


DEC 


DECR 


DER 


DVI 


DIVE 


DIVI 


DJP 


DLD 


DMOVSD 


DMOVXD 


DMOVSX 


DMOVXX 


Octal 
Code 


O05xxx 


005211 
005222 
005244 
004x2x 
004x4x 
005311 
005322 
00742x 


0053xx 


004x6x 
17XXxx 

00617x 
006170 


0067 1x 


004x0x 


OO65xN 


OO65xN 
OO65xN 


OO65xN 


Description 


Complement source to destination 
registers 


Complement A register 
Complement B register 
Complement X register 
Double add 

Double AND ~ 


Decrement A register 


_ Decrement B register 


Decrement register 


Decrement source to destination 
registers 


Double Exclusive OR 
Divide 

Divide extended 
Divide immediate 


Decrement Register and Jump (V77.- 
800 extended instructions only) 


Double load 


Double Word(s) Move (V77-800 
extended instructions only) 


Double Word(s) Move: Source Address 
Indexed (V77-800 extended instruc- 
tions only) 


Double Word(s) Move: Destination 
Address Indexed (V77-800 extended 
instructions only) 


Double Word(s) Move: Source and 
Destination Address Indexed (V77-800 
extended instructions only) 


Mnemonic 


DOR 
DST 
DSBU 
DXR 
ERA 
ERAE 
ERAI 
EXC 
EXC2 


FAD 
FADD 
FDV 
FDVD 
FIX 
FLD 
FLDD 


FLT 


FMU 


FMUD 


Octal 
Code 


004x5x 


004x1x 


004x3x 


005344 


13xxxx 


00613x 


006130 


100xxx 


104xxx 


105410 


105503 


105401 


105535 


105621 


105420 


105522 


105425 


105416 


105506 


INDEX OF INSTRUCTIONS 


Description 


Double OR 

Double store 

Double subtract 

Decrement X register 

Exclusive OR memory and A register 
Exclusive OR extended 

Exclusive OR immediate 

External control 

Auxiliary external control 


Add single precision memory to — 
floating point accumulator 


Add double precision memory to 
floating point accumulator 


Single precision floating point 
divide 

Double precision floating point 
divide 

Reformat floating point accumulator 


and store integer in memory 


Load floating point accumulator 
with single precision number 


Load floating point accumulator 
with double precision number 


Reformat single precision integer 
and load into floating point 
accumulator 


Single precision floating point 
multiply 


Double precision floating point 
multiply 


INDEX OF INSTRUCTIONS 


A-4 


Mnemonic 
FSB 


FSBD 


FST 


FSTD 


HLT 
IAR 
IBR 
IJMP 
IME 
INA 
INAB 
INB 
INC 


INCR 


INR 


INRE 
INRI 


IXR 
JAN 


JANM 


Octal 
Code 


105450 


105543 


105600 


105710 


000000 
005111 
005122 
0067xx 
1020xx 
1021xx 
1023xx 
1022xx 
00741x 


0051xx 


O4xXxxx 


00604x 


06040 


005144 
001004 


002004 


Description 


Single precision floating point 
subtraction 


Double precision floating point 
subtraction oe 


Store floating point accumulator 
in memory in single precision 
format 

Store floating point accumulator 
in memory in double precision 
format 

Hait 

Increment A register 

Increment B register 

Indexed jump 


Input to memory 


Input to A register 
Input to A and B registers 
Input to B register 
Increment register 


Increment source to destination 
registers 


Increment memory and replace 


Increment memory and replace 
extended 


Increment memory and replace 
immediate 


Increment X register 
Jump if A register negative 


Jump and mark if A register negative 


Mnemonic 


JANZ 


JANZM 


JAP 


JAPM 


JAZ 


JAZM 


JBNZ 


JBNZM 


JBZ 


JBZM 


JDNZ 


JDZ 


JIF 


JIFM 


JMP 


JMPM 


JN 


JNZ 


JOF 


JOFN 


JOFM 


JOFNM 


Octal 
Code 


001016 


002016 


001002 


002002 


001010 


002010 


001026 


002026 


001020 


002020 


00677x 


00676x - 


001xxx 


002xxx 


001000 


002000 


00674x 


00673x 


001001 


001007 


002001 


002007 


INDEX OF INSTRUCTIONS 


Description 


| Jump 


Jump 
Jump 
Jump 
Jump 
Jump 
Jump 
Jump 
Jump 
Jump 


Jump 


if A register not zero 
and mark if A register not zero 
if A register positive 
and mark if A register positive 


f A register zero 


and mark if A register zero 


f B register not zero 

and mark if B register not zero 
if B register zero 

and mark if B register zero 


if double precision register 


not zero 


Jump 
zero 


Jump 
Jump 
Jump 
Jump 
Jump 
Jump 
Jump 


Jump 
set 


Jump 
set 


Jump 


if double precision register 


if conditions met 

and mark if conditions met 
unconditionally 

and mark unconditionally 
if register negative 

if register not zero 

if overflow indicator set 


if overfiow indicator not 


and mark if overflow indicator 


and mark if overflow indicator 


not set 


INDEX OF INSTRUCTIONS 


A-6 


Mnemonic 


JP 


JSR 


JSIM 


JS2M 


JS3M 


JSIN 


JS2N 


JS3N 


JSINM 


JS2NM 


JS3NM 


JSS1 


JSS2 


JSS3 


JXNZ 


JXNZM 


IXZ 


JXZM 


JZ 


LASL 


LASR 


Octal, 
Code 


00675x 


0065xx 


002100 


002200 


002400 


001106 
001206 
001406 


002106 


002206 


002406 


001100 
001200 
001400 
001046 


002046 


001040 
002040 


00672x 


004400 +n 


004500 + n 


Description 


Jump if register positive 


Jump unconditionally and set return 
in X register 


Jump and mark if SENSE switch 1 
set 


Jump and mark if SENSE switch 2 
set 


Jump and mark if SENSE switch 3 
set 


Jump if SENSE switch 1 not set 
Jump if SENSE switch 2 not set 
Jump if SENSE switch 3 not set 


Jump and mark if SENSE switch 1 not 
set 


Jump and mark if SENSE switch 2 
not set 


Jump and mark if SENSE switch 3 
not set 


Jump if SENSE switch 1 set 
Jump if SENSE switch 2 set 
Jump if SENSE switch 3 set 
Jump if X register not zero 


Jump and mark if X register not 
zero 


Jump if X register zero 

Jump and mark if X register zero 
Jump if register zero 

Long arithmetic shift left 


Long arithmetic shift right 


Mnemonic 


LBT 


LD 


LDA 


LDAE 


LDAI 


LDB 


LDBE 


LDBI 


LDI 


LDX 


LDXE 


LDXI 


LLERL 


LLSR 


LRLA 


LRLB 


LSRA 


LSRB 


MERG 


MUL. 


MULE 


MuULI 


NOP 


OAB 


Octal 
Code 


00746x 


0070xx 


O1xXxxx 


00601x 


006010 


O2xxXxx 


00602x 


006020 


00744x 


O3XXxx 


00603x 


006030 


004440 +n 


004540 +n 


004240 +n 


004040 +n 


004340 +n 


004140 + n 


0050xx 


16xxxx 


00616x 


006160 


005000 


1033xx 


INDEX OF INSTRUCTIONS 


Description 
Load byte 


Load 
Load A register 


Load A register extended 


Load A register immediate 
Load B register 

Load B register extended 
Load B register immediate 
Load immediate 

Load X register 

Load X register extended 
Load X register immediate 
Long logical rotation left 
Long logical rotation right 
Logical rotation left A register 
Logical rotation left B register 
Logical shift right A register 
Logical shift right B register 


Merge source to destination 
registers 


Multiply 

Multiply extended 
Multiply immediate 
No operation 


Output OR of A and B registers 


A-7 


INDEX OF INSTRUCTIONS 


Mnemonic 


OAR 


OBR 


OME 


ORA 


ORAE 


ORAI 


RGLD. 


RGST 


ROF 


SB 


Octal 
Code 


1031xx 


1032xx 


1030xx 


11xxxx 


00611x 


006110 


0065 1x 


00653x 


007400 


0073xx 


0076xx 


00747x 


101xxx 


007401 


005711 


005722 


005744 


0066xx 


007 1xx 


O5xxxx 


00605x 


006050 


O6xxxxX 


00606x 


Description 


Output from A register 
Output from B register 
Output from memory 

OR memory and A register 
OR extended 

OR immediate 


Registers Load: Direct, Indexed (V77- 
800 extended instructions only) 


Registers Store: Direct, Indexed (V77- 
800 extended instructions only) 


Reset overflow indicator 

Subtract 

Subtract register 

Store byte 

Program sense 

Set overflow indicator 

Subtract overflow from A register 
Subtract overflow from B register 
Subtract overflow from X register 
Skip if register equal 

Store 

Store A register 

Store A register extended 

Store A register immediate 

Store B register 


Store B register extended 


Mnemonic 


STBI 


STBYTS 


STWRDS 


STX 
STXE 
STXI 
SUB 


SUBE 


XAP 


XAZ 


Octal 
Code 


006060 


007407 


007406 


O7XxxxX 


00607x 


006070 


14xxxx 


00614x 


006140 


0077xx 


005012 


005014 


005021 


005024 


007402 


005041 


005042 


005001 


005002 


005004 


003004 


003016 


003002 


003010 


INDEX OF INSTRUCTIONS 


Description 


Store B register immediate 


Store Bytes (V77-800 extended 
structions only) 


Store Words (V77-800 extended in- 


structions only) 

Store X register 

Store X register extended 

Store X register immediate 
Subtract memory from A register 
Subtract extended 

Subtract immediate 

Transfer 

Transfer A register to B register 
Transfer A register to X register 
Transfer B register to A register 
Transfer B register to X register 
Transfer switches to A register 
Transfer X register to A register 
Transfer X register to B register 
Transfer zero to A register 
Transfer zero to B register 
Transfer zero to X register 
Execute if A register negative 
Execute if A register not zero 
Execute if A register positive 


Execute if A register zero 


INDEX OF INSTRUCTIONS 


Octal 
Mnemonic Code Description 
XBNZ 003026 Execute if B register not zero 
XBZ 003020 Execute if B register zero 
XEC 003000 Execute unconditionally 
XIF 003xxx Execute if conditions met 
XOF 003001 Execute if overflow indicator set 
XOFN 003007 Execute if overflow indicator not 

set 

XS1 003100 Execute if SENSE switch 1 set 
XS2 003200 Execute if SENSE switch 2 set 
XS3 003400 Execute if SENSE switch 3 set 
XSIN 003106 . Execute if SENSE switch 1 not set 
XS2N 003206 Execute if SENSE switch 2 not set 
XS3N 003406 Execute if SENSE switch 3 not set 
XXNZ 003046 Execute if X register not zero 
XXZ 003040 Execute if X register zero 
ZERO 00500X Zero (clear) registers 


NOTE: n = shift count 


APPENDIX B 
V70 SERIES ASCII CHARACTER CODES 


Decimal Character 029 026 Description 

128 NUL Null 

129 SOH | Start of Heading 
130 STX Start of Text 

131 ETX End of Text 

132 EOT End of Transmission 
133 ENQ . Enquiry 

134 ACK Acknowledge 

135 BEL Bell 

136 BS Backspace 

137 HT Horizontal Tab 
138 LF Line Feed 

139 VT Vertical Tab 

140 FF Form Feed 

141 CR Carriage Return 
142 SO Shift Out 

143 S| Shift In 

144 DLE Data Link Escape 
145 DC1 Device Control! 1 
146 DC2 Device Control 2 
147 DC3 Device Control 3 
148 DC4 Device Control 4 
149 NAK Negative Acknowledge 
150 SYN Synchronous File 


‘V70 SERIES ASCII CHARACTER CODES 


Octal 
227 


230 


231 


232 


233 


234 


235 


236 


237 


240 


241 


242 


243 


244 


245 


246 


247 


250 


251 


252 


253 


254 


255 


256 


257 


Decimal 


151 


152 


153 


154 


155 


156 


157 


158 


159 


160 


161 


162 


163 


164 


165 


166 


167 


168 


169 


170 


171 


172 


173 


174 


175 


Character 


ETB 


CAN 


EM 


SUB 


ESC 


% 


029 


(blank) 
11/2/8 
7/8 
3/8 
11/3/8 
0/4/8 
12 

5/8 
12/5/8 
11/5/8 
11/4/8 
12/6/8 
0/3/8 
11 
12/3/8 


0/1 


026 


(blank) 
11/2/8 
0/5/8 
0/7/8 
11/3/8 
11/7/8 
12/7/8 
4/8 


0/4/8 


12/4/8 


11/4/8 


12 


0/3/8 


11 


12/3/8 


0/1 


Description 


End of Transmission 
Block 


Cancel 

End of Medium 
Substitute 
Escape 

File Separator 
Group Separator 
Record Separator 
Unit Separator 
Space 
Exclamation Point 
Quotation Mark 
Pound Sign 
Dollar Sign 
Percent Sign 
Ampersand 
Apostrophe (prime) 
Left Paren 

Right Paren 
Asterisk 

Plus Sign 

Comma 

Minus Sign 


Period 


Slash 


V70 SERIES ASCII CHARACTER CODES 


Octal Decimal Character 029 026 Description 
260 176 me) 0 0 

261 177 1 1 1 

262 178 2 2 2 

263 179 3 3 3 

264 180 4 4 4 

265 184 5 5 5 

266 182 6 6 6 

267 183 7 r -* | rg 

270 184 8 8 8 

271 185 9 9 9 

272 186 2/8 5/8 Colon 

273 187; 11/6/8  11/66/8 — Semi-Colon 
274 188 < 12/4/8 12/6/8 Less Than 
275 189 = 6/8 3/8 Equal Sign 
276 190 > 0/6/8 6/8 Greater Than 
277 191 ? 0/7/8 12/2/8 Question Mark 
300 192 @ 4/8 0/2/8 At 

301 193 A 12/1 12/1 

302 194 B 12/2 12/2 

303 195 C 12/3 12/3 

304 196 D 12/4 12/4 

305 197 E 12/5 12/5 

306 198 F 12/6 12/6 

307 199 G © 12/7 12/7 

310 200 H 12/8 12/8 

311 201 | 12/9 12/9 


B-3 


V70 SERIES ASCII CHARACTER CODES 


Octal 
312 


313 
314 
315 
316 
317 
320 
321 
322 
323 
324 
325 
326 
327 
330 
331 
332 
333 
334 
335 
336 
337 
340 
341 


342 


B-4 


Decimal 


202 
203 
204 
205 
206 
207 
208 
209 
210 
211 
212 
213 
214 
215 
216 
217 
218 
219 
220 
221 
222 
223 
224 
225 


226 


Character 


J 


K 


029 
11/1 


11/2 
11/3 © 
11/4 
11/5 
11/6 
11/7 
11/8 
11/9 
0/2 
0/3 
0/4 
0/5 
0/6 
0/7 
0/8 
0/9 
12/2/8 
11/7/8 
0/2/8 
12/7/8 


0/5/8 


026 
11/1 


11/2 


11/3 


11/4 


11/5 


11/6 


11/7 


11/8 


11/9 


0/2 


0/3 


0/4 


0/5 


0/6 


0/7 


~ 0/8 


0/9 

12/5/8 Left Bracket 

0/6/8 Backsiash 

11/5/8 Right Bracket 

7/8 Vertical Arrow 

2/8 Horizontal Arrow 


Accent Grave 


